/* ================================================================
   AIDevExpert — Joomla Development Page
   Modular CMS blueprint design
   Typography controlled: 26px max headings, 600 weight
   ================================================================ */

.page-joom{
  overflow-x:hidden;
  background:#f6fbff;
  color:#0f172a;
}
.page-joom *{box-sizing:border-box}
.page-joom h1,
.page-joom h2,
.page-joom h3{
  font-size:26px!important;
  line-height:1.24!important;
  font-weight:600!important;
  letter-spacing:-.025em!important;
}
.page-joom p,
.page-joom li,
.page-joom span,
.page-joom a,
.page-joom button{font-weight:400}
.joom-reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.joom-reveal.visible{opacity:1;transform:none}
.joom-reveal--d2{transition-delay:.12s}
.joom-label{
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin-bottom:12px;
  color:#0b75bd;
  font-size:11px;
  font-weight:600!important;
  letter-spacing:.15em;
  text-transform:uppercase;
}
.joom-label::before{content:"";width:28px;height:1px;background:currentColor}
.joom-section{padding:68px 0;position:relative}
.joom-section-head{text-align:center;max-width:790px;margin:0 auto 34px}
.joom-section-head .joom-label{justify-content:center}
.joom-section-head .joom-label::before{display:none}
.joom-section-head h2,
.joom-section-copy h2{margin:0 0 12px;color:#0f172a}
.joom-section-head p,
.joom-section-copy p{color:#64748b;font-size:14.5px;line-height:1.74;margin:0}
.joom-btn{
  display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:11px 18px;border-radius:999px;border:1px solid transparent;text-decoration:none;font-size:13px;font-weight:600!important;line-height:1;white-space:nowrap;transition:transform .22s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease,color .22s ease
}
.joom-btn:hover{transform:translateY(-2px);text-decoration:none}
.joom-btn--primary{background:#062033;color:#fff;box-shadow:0 14px 34px rgba(6,32,51,.18)}
.joom-btn--primary:hover{background:#0b75bd;color:#fff}
.joom-btn--ghost{background:#fff;color:#0f172a;border-color:rgba(15,23,42,.12);box-shadow:0 10px 24px rgba(15,23,42,.06)}
.joom-btn--light{background:#fff;color:#062033}
.joom-btn--outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.joom-btn--outline:hover{background:rgba(255,255,255,.1);color:#fff}

/* Hero */
.joom-hero{
  position:relative;
  overflow:hidden;
  padding:78px 0 72px;
  background:
    radial-gradient(circle at 14% 16%,rgba(11,117,189,.18),transparent 30%),
    radial-gradient(circle at 84% 14%,rgba(20,184,166,.16),transparent 32%),
    linear-gradient(135deg,#ffffff 0%,#f6fbff 54%,#eef9ff 100%);
  border-bottom:1px solid rgba(15,23,42,.08);
}
.joom-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(11,117,189,.055) 1px,transparent 1px),
    linear-gradient(0deg,rgba(11,117,189,.055) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:linear-gradient(to bottom,transparent,black 14%,black 88%,transparent);
}
.joom-hero__inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) 480px;
  gap:46px;
  align-items:center;
}
.joom-hero h1{margin:0 0 14px;color:#0f172a;max-width:720px}
.joom-hero p{color:#64748b;font-size:15px;line-height:1.78;margin:0 0 24px;max-width:680px}
.joom-hero__actions{display:flex;flex-wrap:wrap;gap:12px}

.joom-blueprint{
  position:relative;
  min-height:410px;
  border-radius:34px;
  background:#062033;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 30px 80px rgba(6,32,51,.22);
  overflow:hidden;
}
.joom-blueprint::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px),
    linear-gradient(0deg,rgba(255,255,255,.055) 1px,transparent 1px),
    radial-gradient(circle at 50% 50%,rgba(11,117,189,.28),transparent 35%);
  background-size:32px 32px,32px 32px,auto;
}
.joom-blueprint__core{
  position:absolute;
  z-index:3;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:190px;
  height:138px;
  border-radius:28px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  backdrop-filter:blur(12px);
}
.joom-blueprint__core span{
  display:inline-flex;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(20,184,166,.16);
  color:#99f6e4;
  font-size:11px;
  font-weight:600!important;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.joom-blueprint__core strong{
  color:#fff;
  font-size:15px;
  font-weight:600!important;
  line-height:1.35;
}
.joom-blueprint__node{
  position:absolute;
  z-index:3;
  padding:10px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  font-size:12px;
  font-weight:600!important;
  backdrop-filter:blur(10px);
}
.joom-blueprint__node--a{left:35px;top:78px}
.joom-blueprint__node--b{right:38px;top:72px}
.joom-blueprint__node--c{left:60px;bottom:84px}
.joom-blueprint__node--d{right:58px;bottom:82px}
.joom-blueprint__node--e{left:50%;top:28px;transform:translateX(-50%)}

/* Modules */
.joom-modules{background:#fff}
.joom-module-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.joom-module-card{position:relative;min-height:220px;padding:22px;border-radius:24px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 16px 44px rgba(15,23,42,.07);overflow:hidden;transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}
.joom-module-card::after{content:"";position:absolute;right:-46px;bottom:-56px;width:145px;height:145px;border-radius:50%;background:rgba(11,117,189,.09)}
.joom-module-card:hover{transform:translateY(-5px);box-shadow:0 28px 66px rgba(15,23,42,.12);border-color:rgba(11,117,189,.25)}
.joom-module-card > span{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:14px;background:#eaf6ff;color:#0b75bd;font-size:11px;font-weight:600!important;margin-bottom:17px}
.joom-module-card h3{margin:0 0 10px;color:#0f172a}
.joom-module-card p{margin:0;color:#64748b;font-size:13.5px;line-height:1.68}

/* Workflow */
.joom-workflow{
  background:linear-gradient(135deg,#f6fbff,#fff);
}
.joom-workflow__panel{
  padding:30px;
  border-radius:32px;
  color:#fff;
  background:
    radial-gradient(circle at 10% 0%,rgba(20,184,166,.20),transparent 30%),
    linear-gradient(135deg,#062033,#0b3250);
  box-shadow:0 28px 80px rgba(6,32,51,.18);
}
.joom-workflow__panel h2{color:#fff;margin:0 0 10px}
.joom-workflow__panel p{color:rgba(255,255,255,.70);font-size:14px;line-height:1.68;margin:0 0 24px}
.joom-workflow__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.joom-workflow__grid article{padding:18px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.joom-workflow__grid strong{display:block;color:#fff;font-size:14px;font-weight:600!important;margin-bottom:8px}
.joom-workflow__grid span{display:block;color:rgba(255,255,255,.65);font-size:12.5px;line-height:1.58}

/* Deliver */
.joom-deliver{background:#fff}
.joom-deliver__grid{display:grid;grid-template-columns:minmax(0,.75fr) minmax(0,1.25fr);gap:34px;align-items:center}
.joom-deliver__list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.joom-deliver__list div{position:relative;padding:15px 16px 15px 42px;border-radius:18px;background:#f6fbff;border:1px solid rgba(15,23,42,.08);color:#475569;font-size:13px;line-height:1.55;box-shadow:0 12px 28px rgba(15,23,42,.045)}
.joom-deliver__list div::before{content:"✓";position:absolute;left:15px;top:15px;width:18px;height:18px;border-radius:50%;background:#dff6ff;color:#0b75bd;display:grid;place-items:center;font-size:10px;font-weight:600}

.joom-best{background:#f6fbff}
.joom-best__cloud{display:flex;flex-wrap:wrap;justify-content:center;gap:11px}
.joom-best__cloud span{display:inline-flex;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid rgba(15,23,42,.08);color:#475569;font-size:13px;box-shadow:0 8px 22px rgba(15,23,42,.04)}
.joom-best__cloud span:nth-child(3n+1){background:#eaf6ff;color:#0b75bd}

/* FAQ */
.joom-faq{background:#fff}
.joom-faq__grid{display:grid;grid-template-columns:minmax(0,.75fr) minmax(0,1.25fr);gap:32px;align-items:start}
.joom-faq__list{display:grid;gap:12px}
.joom-faq-item{border-radius:18px;border:1px solid rgba(15,23,42,.08);background:#f6fbff;box-shadow:0 12px 30px rgba(15,23,42,.04);overflow:hidden}
.joom-faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;border:0;background:transparent;color:#0f172a;padding:18px 20px;cursor:pointer;text-align:left}
.joom-faq-q span{font-size:14px;font-weight:600!important;line-height:1.45}
.joom-faq-q em{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:#eaf6ff;color:#0b75bd;display:grid;place-items:center;font-style:normal;font-size:18px;line-height:1}
.joom-faq-a{display:none;padding:0 20px 18px}
.joom-faq-item.is-open .joom-faq-a{display:block}
.joom-faq-item.is-open .joom-faq-q em{background:#062033;color:#fff}
.joom-faq-a p{margin:0;color:#64748b;font-size:13.5px;line-height:1.68}

/* CTA */
.joom-cta{background:#f6fbff;padding:66px 0}
.joom-cta__box{display:flex;align-items:center;justify-content:space-between;gap:26px;padding:30px;border-radius:30px;color:#fff;background:radial-gradient(circle at 15% 0%,rgba(20,184,166,.20),transparent 30%),linear-gradient(135deg,#062033,#0b3250);box-shadow:0 28px 80px rgba(6,32,51,.20)}
.joom-cta__box h2{color:#fff;margin:0 0 10px}
.joom-cta__box p{color:rgba(255,255,255,.72);font-size:14px;line-height:1.68;max-width:720px;margin:0}
.joom-cta__actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}

/* Responsive */
@media(max-width:1100px){
  .joom-hero__inner,.joom-deliver__grid,.joom-faq__grid{grid-template-columns:1fr}
  .joom-blueprint{max-width:560px;width:100%;margin:0 auto}
  .joom-workflow__grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .joom-module-grid,.joom-deliver__list{grid-template-columns:repeat(2,1fr)}
  .joom-cta__box{flex-direction:column;align-items:flex-start}
  .joom-cta__actions{justify-content:flex-start}
}
@media(max-width:720px){
  .page-joom h1,.page-joom h2,.page-joom h3{font-size:24px!important}
  .joom-section{padding:54px 0}
  .joom-hero{padding:54px 0 52px}
  .joom-module-grid,.joom-workflow__grid,.joom-deliver__list{grid-template-columns:1fr}
  .joom-blueprint{min-height:340px;border-radius:24px}
  .joom-blueprint__node{display:none}
}
@media(max-width:460px){
  .joom-hero__actions,.joom-cta__actions{flex-direction:column;align-items:stretch}
  .joom-btn{width:100%}
  .joom-cta__box{padding:24px;border-radius:24px}
}
