/* ============================================================
   RYOKO PRO — css/style.css
   Domain: rryoko.com
   Design: Deep Space Blue + Electric Cyan + White
   Hero: Full-width gradient + product centred + signal rings
   Theme: Tech / Travel WiFi / Connected Everywhere
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --space:        #050d1a;
  --space-mid:    #091428;
  --space-lgt:    #0d1e3d;
  --blue:         #0a3275;
  --blue-mid:     #0d47a1;
  --royal:        #1565c0;
  --cyan:         #00b4d8;
  --cyan-mid:     #0096c7;
  --cyan-lgt:     #48cae4;
  --cyan-pale:    #e0f7fa;
  --cyan-xpale:   #b2ebf2;
  --electric:     #00e5ff;
  --white:        #ffffff;
  --off-white:    #f0f4f8;
  --near-white:   #e8eef5;
  --silver:       #90a4be;
  --silver-lgt:   #cdd5e0;
  --text:         #050d1a;
  --text-mid:     #0d1e3d;
  --muted:        #3d5a80;
  --border:       #c5d5e8;
  --border-d:     rgba(255,255,255,.08);
  --radius:       10px;
  --radius-lg:    16px;
  --radius-xl:    24px;
  --radius-pill:  50px;
  --shadow-sm:    0 2px 12px rgba(0,0,0,0.07);
  --shadow:       0 4px 24px rgba(0,0,0,0.11);
  --shadow-h:     0 12px 40px rgba(0,0,0,0.18);
  --shadow-cyan:  0 4px 20px rgba(0,180,216,0.35);
  --shadow-blue:  0 4px 20px rgba(10,50,117,0.25);
}

html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-size:18px;color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.75}

/* ===== NAV ===== */
nav{position:sticky;top:0;z-index:1000;background:var(--space);padding:0 24px;height:72px;
  box-shadow:0 2px 24px rgba(0,0,0,.70);border-bottom:2px solid var(--cyan)}
.nav-inner{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav-logo{font-family:'Jost',sans-serif;font-size:1.65rem;font-weight:900;color:var(--white);text-decoration:none;letter-spacing:1.5px;text-transform:uppercase;flex-shrink:0}
.nav-logo span{color:var(--cyan)}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{color:var(--silver-lgt);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s;white-space:nowrap}
.nav-links a:hover{color:var(--cyan)}
.btn-nav{background:var(--cyan)!important;color:var(--space)!important;font-weight:900!important;font-size:.88rem!important;
  padding:10px 22px!important;border-radius:var(--radius-pill)!important;text-transform:uppercase;transition:filter .2s!important;border:none!important}
.btn-nav:hover{filter:brightness(1.12)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{width:25px;height:2px;background:var(--silver-lgt);display:block;border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--space-mid);
  position:absolute;top:72px;left:0;right:0;padding:24px 32px;gap:18px;z-index:999;border-bottom:2px solid var(--cyan)}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--silver-lgt);text-decoration:none;font-size:1.05rem;font-weight:500}
.mobile-menu .btn-mob{background:var(--cyan);color:var(--space);text-align:center;padding:13px;
  border-radius:var(--radius-pill);font-weight:900;margin-top:6px;text-transform:uppercase}

/* ===== BUTTONS ===== */
.btn-cyan{display:inline-block;background:var(--cyan);color:var(--space);font-family:'Jost',sans-serif;
  font-weight:900;font-size:1.05rem;text-transform:uppercase;padding:15px 38px;
  border-radius:var(--radius-pill);text-decoration:none;transition:filter .2s,transform .15s;
  box-shadow:var(--shadow-cyan);letter-spacing:.5px}
.btn-cyan:hover{filter:brightness(1.10);transform:translateY(-2px)}
.btn-blue{display:inline-block;background:var(--blue-mid);color:var(--white);font-family:'Jost',sans-serif;
  font-weight:900;font-size:1.05rem;text-transform:uppercase;padding:15px 38px;
  border-radius:var(--radius-pill);text-decoration:none;transition:filter .2s,transform .15s;box-shadow:var(--shadow-blue)}
.btn-blue:hover{filter:brightness(1.15);transform:translateY(-2px)}
.btn-outline-cyan{display:inline-block;background:transparent;color:var(--cyan);font-family:'Jost',sans-serif;
  font-weight:700;font-size:1rem;text-transform:uppercase;padding:13px 32px;
  border-radius:var(--radius-pill);border:2px solid var(--cyan);text-decoration:none;transition:all .2s}
.btn-outline-cyan:hover{background:var(--cyan);color:var(--space)}
.btn-outline-white{display:inline-block;background:transparent;color:var(--white);font-family:'Jost',sans-serif;
  font-weight:700;font-size:1rem;text-transform:uppercase;padding:13px 32px;
  border-radius:var(--radius-pill);border:2px solid rgba(255,255,255,.35);text-decoration:none;transition:all .2s}
.btn-outline-white:hover{border-color:var(--cyan);color:var(--cyan)}

/* ===== TITLE BANDS ===== */
.sec-title-band{background:var(--space-mid);padding:48px 40px 40px;text-align:center;
  border-top:3px solid var(--cyan);border-bottom:3px solid var(--cyan)}
.sec-title-band h2{font-family:'Jost',sans-serif;font-size:2.4rem;font-weight:900;
  color:var(--white);letter-spacing:1px;text-transform:uppercase;line-height:1.2}
.sec-title-band p.band-sub{color:rgba(255,255,255,.55);font-size:1rem;margin-top:10px}
.sec-title-band.cyan-band h2{color:var(--cyan)}
.sec-title-band.white-band{background:var(--off-white);border-top-color:var(--border);border-bottom-color:var(--border)}
.sec-title-band.white-band h2{color:var(--text)}
.sec-title-band.white-band p.band-sub{color:var(--muted)}

/* ===== HERO ===== */
.hero{
  background:linear-gradient(135deg, var(--space) 0%, var(--space-mid) 40%, var(--blue) 75%, var(--blue-mid) 100%);
  padding:0; overflow:hidden; position:relative; min-height:640px;
}
/* Animated radial rings — signal effect */
.hero::before{
  content:'';position:absolute;
  left:50%;top:50%;transform:translate(-50%,-50%);
  width:900px;height:900px;border-radius:50%;
  background:transparent;
  box-shadow:
    0 0 0 1px rgba(0,229,255,.06),
    0 0 0 80px rgba(0,229,255,.04),
    0 0 0 160px rgba(0,229,255,.03),
    0 0 0 240px rgba(0,229,255,.02),
    0 0 0 320px rgba(0,229,255,.01);
  pointer-events:none;animation:pulse-ring 4s ease-in-out infinite;
}
@keyframes pulse-ring{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.04)}}

/* Subtle grid texture */
.hero::after{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg,rgba(0,180,216,.03) 0px,rgba(0,180,216,.03) 1px,transparent 1px,transparent 60px),
    repeating-linear-gradient(90deg,rgba(0,180,216,.03) 0px,rgba(0,180,216,.03) 1px,transparent 1px,transparent 60px);
  pointer-events:none;
}

.hero-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:60px;padding:72px 48px 60px;
  position:relative;z-index:1;
}

/* LEFT */
.hero-text-col{display:flex;flex-direction:column;gap:18px}

.hero-kicker{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.25);
  border-radius:var(--radius-pill);padding:6px 18px;
  font-size:.75rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;
  color:var(--cyan);width:fit-content;
}
.hero-kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);
  animation:blink-dot 1.8s infinite}
@keyframes blink-dot{0%,100%{opacity:1}50%{opacity:.2}}

.hero-h1{font-family:'Jost',sans-serif;font-size:3.2rem;font-weight:900;
  color:var(--white);line-height:1.06;letter-spacing:-.5px}
.hero-h1 .accent{color:var(--cyan)}

.hero-sub{font-size:1.05rem;line-height:1.80;color:rgba(255,255,255,.68);max-width:500px}

/* 4-pill spec row */
.hero-spec-row{display:flex;flex-wrap:wrap;gap:8px}
.hspec{display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-pill);padding:7px 16px;
  font-size:.80rem;font-weight:700;color:rgba(255,255,255,.80)}
.hspec.cyan-spec{background:rgba(0,180,216,.12);border-color:rgba(0,229,255,.28);color:var(--cyan)}

.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}
.hero-note{font-size:.82rem;color:rgba(255,255,255,.40)}
.hero-note strong{color:var(--cyan)}

/* RIGHT — product image with glow */
.hero-img-col{display:flex;justify-content:center;align-items:center;position:relative}
.hero-img-col::before{
  content:'';position:absolute;
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(0,180,216,.28) 0%,transparent 70%);
  pointer-events:none;
}
.hero-img-col a img{
  max-width:100%;max-height:480px;object-fit:contain;
  filter:drop-shadow(0 0 50px rgba(0,229,255,.35)) drop-shadow(0 20px 50px rgba(0,0,0,.70));
  transition:transform .6s ease;position:relative;z-index:1;display:block;margin:0 auto;
}
.hero-img-col a:hover img{transform:scale(1.04) translateY(-10px)}

/* ===== TRUST BAR ===== */
.trust-bar{background:rgba(0,180,216,.10);border-bottom:1px solid rgba(0,180,216,.18);
  padding:13px 32px;display:flex;flex-wrap:wrap;justify-content:center;gap:6px 28px}
.trust-bar span{color:var(--cyan-lgt);font-size:.86rem;font-weight:700;
  display:flex;align-items:center;gap:6px;white-space:nowrap}
.trust-bar span::before{content:'✓';color:var(--cyan)}

/* ===== WHAT IS ===== */
.whatis-section{background:var(--white);padding:70px 48px}
.whatis-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;align-items:center;gap:64px}
.whatis-img-wrap{display:flex;justify-content:center}
.whatis-img-wrap img{width:100%;max-width:420px;height:auto;object-fit:contain;
  filter:drop-shadow(0 8px 28px rgba(0,50,117,.15))}
.whatis-text p{font-size:1.1rem;line-height:1.85;color:var(--muted);margin-bottom:18px}

/* ===== FEATURES — 3-col dark cards ===== */
.features-section{background:var(--space-mid);padding:70px 48px}
.feat-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat-card{
  background:var(--space-lgt);border:1px solid var(--border-d);
  border-radius:var(--radius-xl);padding:30px 22px;
  transition:border-color .25s,box-shadow .25s,transform .25s;
  box-shadow:0 4px 18px rgba(0,0,0,.18);position:relative;overflow:hidden;
}
.feat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--cyan-mid),var(--cyan),var(--electric));opacity:0;transition:opacity .3s}
.feat-card:hover{border-color:rgba(0,180,216,.30);box-shadow:0 0 28px rgba(0,180,216,.15),var(--shadow-h);transform:translateY(-4px)}
.feat-card:hover::before{opacity:1}
.fc-icon{width:52px;height:52px;border-radius:var(--radius-lg);
  background:rgba(0,180,216,.10);border:1px solid rgba(0,180,216,.20);
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:14px;transition:background .3s}
.feat-card:hover .fc-icon{background:rgba(0,180,216,.20)}
.feat-card h3{font-family:'Jost',sans-serif;font-size:1.05rem;font-weight:900;color:var(--white);margin-bottom:9px;line-height:1.3}
.feat-card p{font-size:.92rem;line-height:1.70;color:var(--silver)}
.fc-pill{display:inline-block;margin-top:12px;font-size:.70rem;font-weight:800;text-transform:uppercase;
  letter-spacing:1px;padding:3px 11px;border-radius:var(--radius-pill);
  background:rgba(0,180,216,.10);color:var(--cyan);border:1px solid rgba(0,180,216,.22)}

/* ===== PRICING ===== */
.pricing-band{background:var(--space);padding:48px 40px 16px;text-align:center;border-top:3px solid var(--cyan)}
.pricing-band h3{font-family:'Jost',sans-serif;font-size:2rem;font-weight:900;
  color:var(--cyan);margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}
.pricing-band h4{font-family:'Jost',sans-serif;font-size:1.25rem;font-weight:500;
  color:rgba(255,255,255,.55);margin-bottom:0}
.price-img-section{background:var(--off-white);padding:48px;text-align:center}
.price-img-section a img{max-width:900px;width:100%;height:auto;object-fit:contain;
  border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:transform .3s}
.price-img-section a:hover img{transform:scale(1.01)}

/* ===== REVIEWS ===== */
.reviews-section{background:var(--near-white);padding:70px 48px}
.reviews-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.review-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px 22px;text-align:center;transition:box-shadow .3s,transform .3s;
  box-shadow:var(--shadow-sm);border-top:4px solid var(--cyan)}
.review-card:hover{box-shadow:var(--shadow-h);transform:translateY(-4px)}
.reviewer-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 12px;display:block;border:3px solid var(--cyan)}
.review-stars{height:20px;margin:0 auto 10px;display:block}
.review-badge{font-size:.9rem;font-weight:700;color:var(--cyan-mid);margin-bottom:10px}
.review-text{font-size:.96rem;line-height:1.74;color:var(--muted);font-style:italic}
.reviewer-name{margin-top:14px;font-weight:700;color:var(--text-mid);font-size:.92rem}

/* ===== WHY SECTION ===== */
.why-section{background:var(--white);padding:70px 48px}
.why-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.3fr;align-items:center;gap:64px}
.why-img-wrap{display:flex;justify-content:center}
.why-img-wrap img{width:100%;max-width:440px;height:auto;object-fit:contain;
  border-radius:var(--radius-xl);filter:drop-shadow(0 8px 28px rgba(0,50,117,.18))}
.why-text p{font-size:1.1rem;line-height:1.85;color:var(--muted);margin-bottom:18px}

/* ===== GUARANTEE ===== */
.guarantee-section{background:var(--off-white);padding:70px 48px}
.guarantee-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:260px 1fr;align-items:center;gap:60px}
.guarantee-img-wrap{display:flex;justify-content:center}
.guarantee-img-wrap img{width:100%;max-width:260px;height:auto;object-fit:contain}
.guarantee-text p{font-size:1.1rem;line-height:1.85;color:var(--muted);margin-bottom:18px}

/* ===== FAQs ===== */
.faq-section{background:var(--white);padding:70px 48px}
.faq-list{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.faq-question{width:100%;background:none;border:none;text-align:left;padding:20px 24px;
  font-family:'Jost',sans-serif;font-size:1.08rem;font-weight:700;color:var(--text);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;transition:background .2s;line-height:1.4}
.faq-question:hover{background:var(--cyan-pale)}
.faq-arrow{font-size:1.1rem;transition:transform .3s;color:var(--cyan);flex-shrink:0}
.faq-answer{display:none;padding:14px 24px 20px;font-size:1.02rem;line-height:1.8;color:var(--muted);border-top:1px solid var(--border)}
.faq-item.open .faq-answer{display:block}
.faq-item.open .faq-arrow{transform:rotate(180deg)}

/* ===== ORDER HOW ===== */
.order-section{background:var(--near-white);padding:70px 48px}
.order-inner{max-width:900px;margin:0 auto}
.order-inner p{font-size:1.1rem;line-height:1.85;color:var(--muted);margin-bottom:18px}
.order-img-wrap{text-align:center;margin-top:36px}
.order-img-wrap a img{max-width:900px;width:100%;height:auto;object-fit:contain;
  border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:transform .3s}
.order-img-wrap a:hover img{transform:scale(1.01)}

/* ===== CTA FINAL ===== */
.cta-final{
  background:linear-gradient(135deg,var(--space) 0%,var(--space-mid) 50%,var(--blue) 100%);
  padding:80px 48px;text-align:center;border-top:3px solid var(--cyan);
  position:relative;overflow:hidden;
}
.cta-final::before{content:'';position:absolute;left:50%;bottom:-40px;transform:translateX(-50%);
  width:600px;height:250px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(0,229,255,.15) 0%,transparent 65%);pointer-events:none}
.cta-final h2{font-family:'Jost',sans-serif;font-size:2.5rem;font-weight:900;color:var(--white);
  margin-bottom:12px;line-height:1.2;position:relative;z-index:1}
.cta-final h2 span{color:var(--cyan)}
.cta-sub{font-size:1.05rem;color:rgba(255,255,255,.55);margin-bottom:36px;position:relative;z-index:1}
.cta-product-img{max-width:300px;margin:0 auto 32px;position:relative;z-index:1}
.cta-product-img a img{width:100%;height:auto;object-fit:contain;
  filter:drop-shadow(0 0 36px rgba(0,229,255,.35)) drop-shadow(0 14px 40px rgba(0,0,0,.70));transition:transform .4s}
.cta-product-img a:hover img{transform:scale(1.05) translateY(-8px)}
.cta-note{font-size:.88rem;color:rgba(255,255,255,.35);margin-top:14px;position:relative;z-index:1}

/* ===== FOOTER ===== */
footer{background:var(--space);border-top:2px solid rgba(0,180,216,.20)}
.footer-main{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1fr;
  padding:44px 48px;gap:0;border-bottom:1px solid rgba(255,255,255,.06)}
.fb-brand{padding-right:40px;border-right:1px solid rgba(255,255,255,.07)}
.fb-logo{font-family:'Jost',sans-serif;font-size:1.6rem;font-weight:900;color:var(--white);
  text-decoration:none;display:block;margin-bottom:8px;letter-spacing:1px;text-transform:uppercase}
.fb-logo span{color:var(--cyan)}
.fb-tagline{font-size:.86rem;line-height:1.72;color:rgba(255,255,255,.38);margin-bottom:14px}
.fb-pills{display:flex;flex-wrap:wrap;gap:6px}
.fbp{background:rgba(0,180,216,.08);border:1px solid rgba(0,180,216,.18);color:var(--cyan);
  font-size:.70rem;font-weight:800;padding:3px 10px;border-radius:var(--radius-pill)}
.fb-nav{padding:0 24px}
.fb-nav h5{font-family:'Jost',sans-serif;font-size:.72rem;font-weight:800;text-transform:uppercase;
  letter-spacing:2px;color:var(--cyan);margin-bottom:12px;padding-bottom:7px;border-bottom:1px solid rgba(0,180,216,.18)}
.fb-nav ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:9px}
.fb-nav ul li a{color:rgba(255,255,255,.38);text-decoration:none;font-size:.90rem;font-weight:500;
  font-family:'Jost',sans-serif;transition:color .2s;display:flex;align-items:center;gap:5px}
.fb-nav ul li a::before{content:'›';color:var(--cyan);font-size:.9rem;font-weight:700}
.fb-nav ul li a:hover{color:var(--white)}
.footer-legal{max-width:1200px;margin:0 auto;padding:14px 48px 20px;text-align:center}
.footer-legal p{font-size:.80rem;color:rgba(255,255,255,.22);line-height:1.70;margin-bottom:6px}
.footer-legal a{color:rgba(255,255,255,.30);text-decoration:none}
.footer-legal a:hover{color:var(--cyan)}
.footer-copy{font-size:.80rem;color:rgba(255,255,255,.22);font-family:'Jost',sans-serif;
  margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}

/* SCROLL TO TOP */
#scrollTop{position:fixed;bottom:28px;right:20px;z-index:999;display:none;
  width:46px;height:46px;background:var(--cyan);color:var(--space);
  border-radius:50%;text-align:center;line-height:46px;font-size:1.3rem;
  box-shadow:var(--shadow-cyan);cursor:pointer;text-decoration:none;
  transition:background .3s;font-weight:900;border:none;
  align-items:center;justify-content:center}
#scrollTop:hover{background:var(--electric)}

/* FADE-UP */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1100px){.footer-main{grid-template-columns:1fr 1fr}.fb-brand{grid-column:1/-1;border-right:none;border-bottom:1px solid rgba(255,255,255,.07);padding-right:0;padding-bottom:20px;margin-bottom:8px}}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;padding:48px 24px}.hero-h1{font-size:2.5rem}.hero-img-col{order:-1}.feat-grid{grid-template-columns:1fr 1fr}.reviews-grid{grid-template-columns:1fr 1fr}.whatis-inner,.why-grid,.guarantee-inner{grid-template-columns:1fr}.whatis-img-wrap,.why-img-wrap,.guarantee-img-wrap{justify-content:center}}
@media(max-width:640px){nav{padding:0 16px}.nav-links{display:none}.hamburger{display:flex}.hero-h1{font-size:2rem}.feat-grid{grid-template-columns:1fr}.reviews-grid{grid-template-columns:1fr}.sec-title-band{padding:36px 20px 30px}.sec-title-band h2{font-size:1.65rem}.whatis-section,.features-section,.reviews-section,.why-section,.guarantee-section,.faq-section,.order-section{padding:44px 20px}.price-img-section{padding:32px 20px}.cta-final{padding:56px 20px}.cta-final h2{font-size:1.85rem}.footer-main,.footer-legal{padding:28px 20px}.fb-nav{padding:0}.trust-bar{padding:12px 20px;gap:6px 18px}.footer-main{grid-template-columns:1fr}}