/* ============================================================
   YASI GROUP GLOBAL NETWORK — Main Stylesheet
   style.css
   ============================================================ */

:root {
  --crimson:      #C0004B;
  --crimson-dark: #8a0035;
  --white:        #ffffff;
  --off-white:    #fafaf9;
  --light-gray:   #f4f2ef;
  --mid-gray:     #e8e4de;
  --text-dark:    #111010;
  --text-mid:     #555555;
  --text-light:   #888888;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { font-family:'DM Sans',sans-serif; background:var(--white); color:var(--text-dark); overflow-x:hidden; }

/* ── Custom Cursor (desktop only) ── */
.cursor, .cursor-ring { display: none; }
@media (hover: hover) and (pointer: fine) {
  .cursor { width:12px; height:12px; background:var(--crimson); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform 0.1s ease; mix-blend-mode:multiply; display:block; }
  .cursor-ring { width:36px; height:36px; border:1.5px solid var(--crimson); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:all 0.15s ease; opacity:0.5; display:block; }
}

/* ── Navigation ── */
nav { position:fixed; top:0; left:0; right:0; z-index:200; display:flex; align-items:center; justify-content:space-between; padding:16px 60px; transition:all 0.4s ease; }
nav.scrolled { background:rgba(255,255,255,0.97); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); padding:10px 60px; box-shadow:0 1px 0 var(--mid-gray); }
/* ── Nav logo ── */
.nav-logo img { height:60px; width:auto; display:block; transition:height 0.3s; }
nav.scrolled .nav-logo img { height:48px; }

/* ── YASI Group AU card: white PNG used directly, no filter ── */

/* ── Footer logo: white PNG, full size ── */
.footer-logo img { height:64px; width:auto; }
.nav-links { display:flex; gap:40px; list-style:none; }
.nav-links a { text-decoration:none; color:var(--text-mid); font-size:0.83rem; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; transition:color 0.2s; }
.nav-links a:hover { color:var(--crimson); }
.nav-cta { background:var(--crimson); color:white; padding:10px 24px; border-radius:2px; font-size:0.78rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; text-decoration:none; transition:background 0.2s,transform 0.2s; }
.nav-cta:hover { background:var(--crimson-dark); transform:translateY(-1px); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; z-index:201; }
.nav-hamburger span { display:block; width:26px; height:2px; background:var(--text-dark); border-radius:2px; transition:all 0.3s ease; }
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-menu { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--white); z-index:199; flex-direction:column; align-items:center; justify-content:center; gap:36px; opacity:0; pointer-events:none; transition:opacity 0.3s ease; }
.mobile-menu.open { opacity:1; pointer-events:all; }
.mobile-menu a { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:var(--text-dark); text-decoration:none; transition:color 0.2s; }
.mobile-menu a:hover { color:var(--crimson); }
.mobile-menu .mobile-cta { background:var(--crimson); color:white; padding:14px 36px; border-radius:2px; font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; margin-top:8px; }

/* ── Hero ── */
#hero { min-height:100vh; display:flex; flex-direction:column; justify-content:center; position:relative; overflow:hidden; background:var(--white); padding:140px 60px 80px; }
.hero-bg-text { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:'Bebas Neue',cursive; font-size:clamp(120px,20vw,280px); color:transparent; -webkit-text-stroke:1px rgba(192,0,75,0.055); white-space:nowrap; pointer-events:none; animation:bgDrift 20s ease-in-out infinite alternate; z-index:0; }
@keyframes bgDrift { from{transform:translate(-50%,-50%) scale(1);} to{transform:translate(-48%,-52%) scale(1.04);} }
.hero-line { position:absolute; top:0; right:140px; width:1px; height:100%; background:linear-gradient(to bottom,transparent,var(--mid-gray) 30%,var(--mid-gray) 70%,transparent); z-index:1; }
.hero-tag { font-size:0.68rem; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--crimson); display:flex; align-items:center; gap:12px; margin-bottom:28px; position:relative; z-index:1; opacity:0; animation:fadeUp 0.8s 0.2s forwards; }
.hero-tag::before { content:''; width:36px; height:1px; background:var(--crimson); }
.hero-headline { font-family:'Playfair Display',serif; font-size:clamp(48px,7.5vw,114px); font-weight:900; line-height:0.93; color:var(--text-dark); max-width:900px; position:relative; z-index:1; opacity:0; animation:fadeUp 0.8s 0.4s forwards; }
.hero-headline .accent { color:var(--crimson); font-style:italic; }
.hero-sub { margin-top:32px; font-size:1.05rem; color:var(--text-mid); max-width:480px; line-height:1.75; position:relative; z-index:1; opacity:0; animation:fadeUp 0.8s 0.6s forwards; }
.hero-actions { margin-top:48px; display:flex; align-items:center; gap:28px; flex-wrap:wrap; position:relative; z-index:1; opacity:0; animation:fadeUp 0.8s 0.8s forwards; }
.btn-primary { background:var(--crimson); color:white; padding:16px 40px; border-radius:2px; font-size:0.83rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; text-decoration:none; transition:all 0.3s; }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(192,0,75,0.3); }
.btn-ghost { color:var(--text-dark); font-size:0.85rem; font-weight:500; text-decoration:none; display:flex; align-items:center; gap:8px; transition:gap 0.2s,color 0.2s; }
.btn-ghost:hover { gap:16px; color:var(--crimson); }
.hero-stats { position:absolute; right:60px; bottom:80px; display:flex; flex-direction:column; gap:28px; z-index:2; opacity:0; animation:fadeUp 0.8s 1s forwards; }
.stat-item { text-align:right; }
.stat-num { font-family:'Bebas Neue',cursive; font-size:3.5rem; line-height:1; color:var(--crimson); }
.stat-label { font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-light); display:block; margin-top:2px; }
.scroll-indicator { position:absolute; bottom:40px; left:60px; display:flex; align-items:center; gap:12px; opacity:0; animation:fadeUp 0.8s 1.2s forwards; z-index:2; }
.scroll-line { width:1px; height:56px; background:linear-gradient(to bottom,var(--crimson),transparent); animation:scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.scroll-text { font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--text-light); writing-mode:vertical-rl; }
@keyframes fadeUp { from{opacity:0;transform:translateY(30px);} to{opacity:1;transform:translateY(0);} }

/* ── World Map ── */
#world { padding:100px 0; background:var(--text-dark); position:relative; overflow:hidden; }
.world-header { text-align:center; padding:0 60px 60px; position:relative; z-index:2; }
.section-tag { font-size:0.67rem; font-weight:600; letter-spacing:0.25em; text-transform:uppercase; color:var(--crimson); display:inline-flex; align-items:center; gap:12px; margin-bottom:20px; }
.section-tag::before, .section-tag::after { content:''; width:28px; height:1px; background:var(--crimson); }
.world-title { font-family:'Playfair Display',serif; font-size:clamp(30px,5vw,68px); color:white; font-weight:900; line-height:1.1; }
.world-title em { color:var(--crimson); font-style:italic; }
.map-container { position:relative; width:100%; max-width:1100px; margin:0 auto; padding:0 40px; }
.world-svg-wrap { position:relative; width:100%; padding-bottom:52%; }
.world-svg-wrap svg { position:absolute; inset:0; width:100%; height:100%; }
.map-dot circle.outer { fill:none; stroke:var(--crimson); animation:mapPulse 2.5s ease-out infinite; }
.map-dot circle.inner { fill:var(--crimson); filter:drop-shadow(0 0 8px rgba(192,0,75,0.8)); }
@keyframes mapPulse { 0%{r:4;opacity:1;} 100%{r:18;opacity:0;} }
.map-line { stroke:var(--crimson); stroke-width:0.8; fill:none; opacity:0.4; stroke-dasharray:6 4; animation:dashMove 3s linear infinite; }
@keyframes dashMove { from{stroke-dashoffset:0;} to{stroke-dashoffset:-40;} }
.map-label { font-family:'DM Sans',sans-serif; font-size:11px; fill:white; font-weight:600; letter-spacing:0.05em; }
.map-label-sub { font-size:8px; fill:rgba(255,255,255,0.5); font-weight:400; }
.dot-glow { fill:var(--crimson); opacity:0.12; animation:glowPulse 2.5s ease-in-out infinite; }
@keyframes glowPulse { 0%,100%{r:20;opacity:0.12;} 50%{r:30;opacity:0.06;} }

/* ── Subsidiaries ── */
#subsidiaries { padding:100px 60px; background:var(--off-white); }
.subs-header  { margin-bottom:60px; }
.subs-title   { font-family:'Playfair Display',serif; font-size:clamp(28px,4vw,56px); font-weight:900; line-height:1.1; }
.subs-title em { color:var(--crimson); font-style:italic; }
.subs-subtitle { margin-top:16px; font-size:1rem; color:var(--text-mid); max-width:420px; }
.country-section { margin-bottom:64px; }
.country-label { font-size:0.64rem; font-weight:600; letter-spacing:0.25em; text-transform:uppercase; color:var(--crimson); display:flex; align-items:center; gap:12px; margin-bottom:28px; }
.country-label::after { content:''; flex:1; height:1px; background:var(--mid-gray); }
.cards-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }
.sub-card { background:white; border:1px solid var(--mid-gray); border-radius:4px; padding:36px; position:relative; overflow:hidden; transition:all 0.4s ease; text-decoration:none; color:inherit; display:block; }
.sub-card::before { content:''; position:absolute; top:0; left:0; width:3px; height:0; background:var(--crimson); transition:height 0.4s ease; }
.sub-card:hover { border-color:transparent; box-shadow:0 20px 60px rgba(0,0,0,0.1); transform:translateY(-4px); }
.sub-card:hover::before { height:100%; }
.card-logo-wrap { height:64px; display:flex; align-items:center; margin-bottom:24px; }
.card-logo-wrap img { max-height:58px; max-width:190px; width:auto; object-fit:contain; object-position:left center; }
.card-type { font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--crimson); font-weight:600; margin-bottom:12px; }
.card-name { font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700; margin-bottom:14px; line-height:1.3; }
.card-desc { font-size:0.87rem; color:var(--text-mid); line-height:1.65; margin-bottom:28px; }
.card-url  { font-size:0.74rem; color:var(--text-light); letter-spacing:0.04em; transition:color 0.2s; }
.sub-card:hover .card-url { color:var(--crimson); }
.card-arrow { position:absolute; bottom:32px; right:32px; width:34px; height:34px; border:1px solid var(--mid-gray); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.8rem; color:var(--text-light); transition:all 0.3s; }
.sub-card:hover .card-arrow { background:var(--crimson); border-color:var(--crimson); color:white; transform:rotate(45deg); }
.sub-card.parent { background:var(--crimson); color:white; border-color:transparent; }
.sub-card.parent .card-type  { color:rgba(255,255,255,0.75); }
.sub-card.parent .card-desc  { color:rgba(255,255,255,0.82); }
.sub-card.parent .card-url   { color:rgba(255,255,255,0.65); }
.sub-card.parent:hover .card-url { color:white; }
.sub-card.parent::before     { background:rgba(255,255,255,0.4); }
.sub-card.parent .card-arrow { border-color:rgba(255,255,255,0.3); color:white; }
.sub-card.parent:hover .card-arrow { background:white; color:var(--crimson); border-color:white; }
.sub-card.parent:hover { box-shadow:0 20px 60px rgba(192,0,75,0.4); }
/* ── Sub-card parent: white PNG used directly on crimson ── */

/* ── About ── */
#about { padding:120px 60px; display:grid; grid-template-columns:1fr 1fr; gap:100px; align-items:center; }
.about-visual { position:relative; }
.about-big-num { font-family:'Bebas Neue',cursive; font-size:20vw; line-height:0.85; color:transparent; -webkit-text-stroke:2px var(--mid-gray); position:absolute; top:-20px; left:-40px; z-index:0; pointer-events:none; }
.about-card { background:var(--light-gray); border-radius:4px; padding:48px; position:relative; z-index:1; }
.about-card-title { font-family:'Playfair Display',serif; font-size:1.75rem; font-weight:700; margin-bottom:20px; }
.about-card-body  { font-size:0.94rem; color:var(--text-mid); line-height:1.8; }
.about-values     { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:30px; }
.value-chip { background:white; border-radius:2px; padding:13px 16px; font-size:0.78rem; font-weight:600; color:var(--text-dark); display:flex; align-items:center; gap:8px; }
.value-chip::before { content:''; width:6px; height:6px; background:var(--crimson); border-radius:50%; flex-shrink:0; }
.about-eyebrow { font-size:0.67rem; font-weight:600; letter-spacing:0.25em; text-transform:uppercase; color:var(--crimson); margin-bottom:20px; display:flex; align-items:center; gap:12px; }
.about-eyebrow::before { content:''; width:28px; height:1px; background:var(--crimson); }
.about-heading { font-family:'Playfair Display',serif; font-size:clamp(28px,3.5vw,50px); font-weight:900; line-height:1.1; margin-bottom:22px; }
.about-heading em { color:var(--crimson); font-style:italic; }
.about-body   { font-size:0.97rem; color:var(--text-mid); line-height:1.8; margin-bottom:20px; }
.about-list   { list-style:none; }
.about-list li { display:flex; align-items:flex-start; gap:12px; font-size:0.88rem; color:var(--text-mid); padding:10px 0; border-bottom:1px solid var(--mid-gray); }
.about-list li::before { content:'→'; color:var(--crimson); flex-shrink:0; }

/* ── Sectors ── */
#sectors { padding:80px 0; background:var(--text-dark); overflow:hidden; }
.sectors-header { text-align:center; margin-bottom:60px; padding:0 60px; }
.sectors-title  { font-family:'Playfair Display',serif; font-size:clamp(28px,4vw,56px); color:white; font-weight:900; }
.sectors-title em { color:var(--crimson); font-style:italic; }
.sectors-marquee-wrap { position:relative; -webkit-mask:linear-gradient(to right,transparent,black 12%,black 88%,transparent); mask:linear-gradient(to right,transparent,black 12%,black 88%,transparent); }
.sectors-marquee { display:flex; animation:marquee 25s linear infinite; width:max-content; }
@keyframes marquee { from{transform:translateX(0);} to{transform:translateX(-50%);} }
.sector-pill { display:flex; align-items:center; gap:12px; padding:15px 28px; border:1px solid rgba(255,255,255,0.1); white-space:nowrap; margin:0 8px; border-radius:2px; font-size:0.88rem; color:rgba(255,255,255,0.65); font-weight:500; transition:all 0.3s; }
.sector-pill:hover { border-color:var(--crimson); color:white; }
.sector-icon { font-size:1.1rem; }

/* ── CTA ── */
#cta { padding:100px 60px; background:var(--crimson); text-align:center; position:relative; overflow:hidden; }
.cta-bg { position:absolute; inset:0; background:radial-gradient(circle at 30% 50%,rgba(255,255,255,0.1),transparent 60%),radial-gradient(circle at 70% 50%,rgba(0,0,0,0.15),transparent 60%); pointer-events:none; }
.cta-tag      { font-size:0.68rem; letter-spacing:0.25em; text-transform:uppercase; color:rgba(255,255,255,0.7); margin-bottom:20px; position:relative; z-index:1; }
.cta-headline { font-family:'Playfair Display',serif; font-size:clamp(28px,5vw,72px); color:white; font-weight:900; line-height:1.1; margin-bottom:22px; position:relative; z-index:1; }
.cta-sub      { color:rgba(255,255,255,0.8); font-size:1rem; max-width:480px; margin:0 auto 48px; line-height:1.7; position:relative; z-index:1; }
.cta-buttons  { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1; }
.btn-white { background:white; color:var(--crimson); padding:16px 40px; border-radius:2px; font-size:0.83rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; text-decoration:none; transition:all 0.3s; }
.btn-white:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(0,0,0,0.2); }
.btn-outline-white { border:1.5px solid rgba(255,255,255,0.5); color:white; padding:16px 40px; border-radius:2px; font-size:0.83rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; text-decoration:none; transition:all 0.3s; }
.btn-outline-white:hover { border-color:white; background:rgba(255,255,255,0.1); }

/* ── Footer ── */
footer { background:#0a0a0a; padding:80px 60px 40px; color:rgba(255,255,255,0.5); }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:60px; }
.footer-logo { margin-bottom:20px; }
.footer-tagline { font-size:0.88rem; line-height:1.7; margin-bottom:24px; }
.footer-socials { display:flex; gap:10px; }
.social-btn { width:34px; height:34px; border:1px solid rgba(255,255,255,0.1); border-radius:2px; display:flex; align-items:center; justify-content:center; font-size:0.8rem; color:rgba(255,255,255,0.5); text-decoration:none; transition:all 0.2s; }
.social-btn:hover { border-color:var(--crimson); color:var(--crimson); }
.footer-col-title { font-size:0.68rem; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.3); margin-bottom:20px; font-weight:600; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:10px; }
.footer-links a { font-size:0.87rem; color:rgba(255,255,255,0.5); text-decoration:none; transition:color 0.2s; }
.footer-links a:hover { color:white; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06); padding-top:30px; display:flex; justify-content:space-between; align-items:center; }
.footer-legal  { font-size:0.77rem; }
.footer-origin { font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; }
.footer-origin span { color:var(--crimson); }

/* ── Scroll Reveal ── */
.reveal        { opacity:0; transform:translateY(40px);  transition:opacity 0.7s ease,transform 0.7s ease; }
.reveal.visible{ opacity:1; transform:translateY(0); }
.reveal-left        { opacity:0; transform:translateX(-40px); transition:opacity 0.7s ease,transform 0.7s ease; }
.reveal-left.visible{ opacity:1; transform:translateX(0); }
.reveal-right        { opacity:0; transform:translateX(40px);  transition:opacity 0.7s ease,transform 0.7s ease; }
.reveal-right.visible{ opacity:1; transform:translateX(0); }
.d1{transition-delay:0.1s;} .d2{transition-delay:0.2s;} .d3{transition-delay:0.3s;} .d4{transition-delay:0.4s;} .d5{transition-delay:0.5s;}

/* ============================================================
   TABLET  (max-width: 1024px)
   ============================================================ */
@media (max-width: 1024px) {
  nav          { padding:16px 32px; }
  nav.scrolled { padding:10px 32px; }
  #hero        { padding:130px 32px 80px; }
  .hero-stats  { right:32px; }
  #subsidiaries{ padding:80px 32px; }
  #about       { padding:80px 32px; gap:60px; }
  #cta         { padding:80px 32px; }
  footer       { padding:60px 32px 32px; }
  .footer-top  { gap:40px; }
  #world       { padding:80px 0; }
  .world-header{ padding:0 32px 48px; }
  .map-container{ padding:0 24px; }
}

/* ============================================================
   MOBILE  (max-width: 768px)
   ============================================================ */
@media (max-width: 768px) {
  /* Nav */
  nav                       { padding:12px 20px; }
  nav.scrolled              { padding:10px 20px; }
  .nav-links                { display:none; }
  .nav-cta                  { display:none; }
  .nav-hamburger            { display:flex; }
  .nav-logo img             { height:46px; }
  nav.scrolled .nav-logo img{ height:40px; }
  .mobile-menu              { display:flex; }

  /* Hero */
  #hero             { padding:110px 20px 60px; min-height:100svh; }
  .hero-bg-text     { font-size:clamp(80px,28vw,160px); }
  .hero-headline    { font-size:clamp(42px,11vw,72px); line-height:1; }
  .hero-sub         { font-size:0.95rem; margin-top:20px; }
  .hero-actions     { margin-top:32px; flex-direction:column; align-items:flex-start; gap:16px; }
  .btn-primary      { width:100%; text-align:center; padding:15px 24px; }
  .hero-stats       { display:none; }
  .hero-line        { display:none; }
  .scroll-indicator { left:20px; bottom:24px; }

  /* World Map */
  #world            { padding:60px 0; }
  .world-header     { padding:0 20px 32px; }
  .map-container    { padding:0 10px; }
  .world-svg-wrap   { padding-bottom:70%; }

  /* Subsidiaries */
  #subsidiaries     { padding:60px 20px; }
  .cards-row        { grid-template-columns:1fr; }
  .sub-card         { padding:28px; }
  .card-logo-wrap   { height:52px; margin-bottom:18px; }
  .card-logo-wrap img{ max-height:48px; }
  .card-desc        { margin-bottom:40px; }

  /* About */
  #about            { padding:60px 20px; grid-template-columns:1fr; gap:40px; }
  .about-big-num    { display:none; }
  .about-card       { padding:28px; }
  .about-values     { grid-template-columns:1fr; }

  /* Sectors */
  #sectors          { padding:60px 0; }
  .sectors-header   { padding:0 20px 40px; }

  /* CTA */
  #cta              { padding:60px 20px; }
  .cta-buttons      { flex-direction:column; align-items:center; }
  .btn-white,
  .btn-outline-white{ width:100%; max-width:300px; text-align:center; }

  /* Footer */
  footer            { padding:48px 20px 28px; }
  .footer-top       { grid-template-columns:1fr; gap:36px; }
  .footer-logo img  { height:52px; }
  .footer-bottom    { flex-direction:column; gap:10px; text-align:center; }
}

/* ============================================================
   SMALL MOBILE  (max-width: 400px)
   ============================================================ */
@media (max-width: 400px) {
  .hero-headline  { font-size:clamp(36px,12vw,56px); }
  .nav-logo img   { height:38px; }
  .sub-card       { padding:22px; }
  .about-card     { padding:22px; }
  .footer-top     { gap:28px; }
}
