:root{
    --yellow:#f2d400;
    --yellow-shape:#ebd63b;
    --purple:#853b97;
    --purple-dark:#6a2f81;
    --white:#ffffff;
    --text-light:#fff2a6;
    --blog-bg:#f4f4f4;
    --blog-accent:#d60f87;
    --blog-text:#8a55a2;
    --blog-border:#8c3ba0;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    font-family:Arial,Helvetica,sans-serif;
    background:var(--yellow);
    overflow-x:hidden;
    padding-top:104px;
}
a{text-decoration:none}

/* HEADER */
.topbar{
    width:100%;
    height:104px;
    background:var(--yellow);
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:9999;
}
.topbar-inner{width:1010px;height:104px;margin:0 auto;position:relative}
.logo-badge{position:absolute;left:0;top:12px;width:86px;height:86px;border-radius:50%;border:6px solid var(--purple)}
.logo-badge::before{content:"";position:absolute;inset:-4px;border-radius:50%;border:3px solid #d34ea8;clip-path: inset(44% 0 0 0)}
.logo-badge-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#d8c8df;font-size:34px;font-style:italic;line-height:1}
.main-nav{position:absolute;left:95px;top:44px;display:flex;align-items:stretch;background:#efe183;border:1px solid rgba(106,47,129,.18)}
.main-nav a{min-height:34px;padding:0 26px;display:flex;align-items:center;justify-content:center;color:var(--purple-dark);font-size:14px;font-weight:700;border-right:1px solid rgba(106,47,129,.18);white-space:nowrap;position:relative}
.main-nav a:last-child{border-right:none}
.main-nav a.active{background:var(--purple);color:var(--text-light)}
.main-nav a.active::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:-12px;width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid var(--purple)}
.menu-toggle{display:none;position:absolute;right:0;top:28px;background:var(--purple);color:#fff;border:none;border-radius:10px;padding:10px 14px;font-size:20px;cursor:pointer}

/* HOME */
.hero-wix{position:relative;width:100%;height:565px;background:var(--purple);overflow:hidden}
.hero-yellow-shape{position:absolute;left:0;top:0;width:100%;height:160px;background:var(--yellow-shape);clip-path:polygon(0 0,100% 0,100% 33%,82.5% 33%,78.8% 47%,55.3% 44%,0 71%)}
.hero-logo-right{position:absolute;left:1128px;top:8px;z-index:5}
.brand-wordmark{color:var(--purple);font-size:37px;line-height:1;font-weight:500;letter-spacing:-.02em}
.brand-o{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border:2px solid var(--purple);border-radius:50%;font-size:13px;transform:translateY(-3px)}
.brand-sub{margin-top:2px;padding-left:63px;color:#d4572a;font-size:14px;line-height:1}
.hero-photo{position:absolute;left:494px;top:34px;z-index:4}
.photo-ring{width:175px;height:175px;border-radius:50%;background:#b9a3c8;padding:6px;box-shadow:0 10px 26px rgba(45,10,57,.18)}
.photo-placeholder{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;padding:18px;background:linear-gradient(135deg,#d8d8d8 0%,#979797 100%);color:#fff;font-size:18px;font-weight:700}
.hero-title{position:absolute;left:686px;top:0;z-index:4;width:650px;line-height:.96;font-weight:800}
.hello{color:var(--yellow);font-size:57px;margin-bottom:2px}
.line{font-size:58px}.line.white{color:#fff}.line .yellow{color:var(--yellow)}
.line.box span{display:inline-block;background:#fff;color:var(--purple-dark);padding:5px 10px 4px;line-height:1}
.hero-copy{position:absolute;left:494px;top:246px;width:900px;color:#fff;font-size:17px;line-height:1.25;z-index:4}
.hero-copy p{margin-bottom:18px}
.hero-copy strong{font-weight:800}
.portfolio-button{display:inline-flex;width:135px;height:39px;align-items:center;justify-content:center;background:#b164d1;color:#fff;border-radius:7px;font-size:16px}

/* BLOG */
.blog-page{background:var(--blog-bg);padding-bottom:0}
.blog-submenu-wrap{background:var(--blog-bg);padding:18px 0 12px}
.blog-submenu{width:1020px;margin:0 auto;display:flex;align-items:center;gap:28px}
.blog-filter{font-size:14px;font-weight:700;color:#7c347c;padding:10px 0;border-bottom:2px solid transparent}
.blog-filter.active,.blog-filter:hover{color:#702c85}
.blog-search-btn{margin-left:auto;border:none;background:none;color:#8c3ba0;font-size:24px;cursor:pointer}
.blog-list-section{padding:8px 0 58px;background:var(--blog-bg)}
.blog-list{width:1020px;margin:0 auto;display:flex;flex-direction:column;gap:28px}
.blog-card{display:grid;grid-template-columns:48% 52%;background:#fff;border:4px solid var(--blog-border);min-height:306px}
.blog-card-image{position:relative;min-height:300px;overflow:hidden}
.image-placeholder-note{position:absolute;left:16px;bottom:14px;background:rgba(255,255,255,.88);color:#7d3b8f;font-size:12px;font-weight:700;padding:8px 10px;border-radius:4px}
.blog-image-wave{background:linear-gradient(135deg,#38005f 0%,#7d00a4 40%,#2d0048 100%)}
.blog-image-wave::before{content:"";position:absolute;inset:18px;background:
radial-gradient(circle at 10% 55%, rgba(255,255,255,.35) 0 2px, transparent 3px),
linear-gradient(160deg, transparent 0 10%, #ff008b 12% 19%, transparent 21%),
linear-gradient(166deg, transparent 8%, #00d3ff 16% 23%, transparent 25%),
linear-gradient(173deg, transparent 16%, #ffd400 24% 30%, transparent 32%),
linear-gradient(178deg, transparent 20%, #5effd3 30% 36%, transparent 38%);
opacity:.95}
.blog-image-sunset{background:linear-gradient(180deg,#d57e48 0%,#e38b4c 35%,#5a4330 36%,#2d2d2d 100%)}
.blog-image-sunset::before{content:"";position:absolute;left:33%;top:30%;width:76px;height:76px;border-radius:50%;background:#ffd84c;box-shadow:0 0 18px rgba(255,216,76,.5)}
.blog-image-sunset::after{content:"";position:absolute;right:8%;top:28%;width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:58px solid rgba(255,255,255,.8);transform:rotate(18deg)}
.blog-image-fear{background:linear-gradient(180deg,#7f319a 0 16%,#ffffff 16% 78%,#d2b7e8 78% 100%)}
.blog-image-fear::before{content:"miedo?";position:absolute;left:29%;top:14%;font-size:64px;font-weight:800;color:#e50089}
.blog-image-fear::after{content:"";position:absolute;left:7%;bottom:-18px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle at 50% 50%, #ffd400 0 32%, #ff008b 34% 62%, #7a2e92 64% 100%)}
.blog-card-content{padding:22px 28px 18px;display:flex;flex-direction:column}
.blog-card-top{display:flex;align-items:flex-start;justify-content:space-between;position:relative}
.blog-author{display:flex;align-items:center;gap:10px}
.blog-avatar{width:34px;height:34px;border-radius:50%;background:#ccb7d8;color:#7a2e92;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}
.blog-author-name,.blog-date{font-size:14px;color:#9b6aac}
.blog-date{font-size:12px}
.blog-menu-btn{border:none;background:none;color:#c61087;font-size:28px;line-height:1;cursor:pointer;padding:0 4px}
.blog-post-menu{position:absolute;right:0;top:34px;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.16);padding:14px 16px;display:none;z-index:30;min-width:230px}
.blog-post-menu.open{display:block}
.share-entry-btn{border:none;background:none;width:100%;text-align:left;font-size:14px;color:#666;cursor:pointer;display:flex;gap:12px;align-items:center}
.blog-category{margin-top:18px;color:#7d2f8f;font-weight:700;font-size:17px}
.blog-title{margin-top:14px;color:var(--blog-accent);font-size:28px;line-height:1.1}
.blog-excerpt{margin-top:14px;color:var(--blog-text);font-size:18px;line-height:1.45}
.blog-meta{margin-top:auto;padding-top:18px;border-top:1px solid #e0d2e5;display:flex;align-items:center;justify-content:space-between}
.blog-stats{display:flex;gap:18px;flex-wrap:wrap;color:#a06db1;font-size:13px}
.blog-like-btn{border:none;background:none;color:#ef4b67;display:flex;align-items:center;gap:7px;font-size:22px;cursor:pointer}
.blog-like-count{font-size:18px;color:#a06db1}
.blog-like-btn.liked .blog-like-heart{color:#ef4b67}
.blog-like-btn.liked .blog-like-heart::before{content:"♥"}
.blog-like-heart::before{content:"♡"}
.share-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.66);display:none;align-items:center;justify-content:center;z-index:200}
.share-modal-overlay.open{display:flex}
.share-modal-close-x{position:absolute;right:22px;top:16px;border:none;background:none;color:#fff;font-size:46px;cursor:pointer}
.share-modal-box{background:#fff;padding:52px 38px 56px;min-width:425px;text-align:center;box-shadow:0 12px 30px rgba(0,0,0,.24)}
.share-modal-box h3{font-size:19px;margin-bottom:34px;color:#111}
.share-icons-row{display:flex;justify-content:center;gap:24px}
.share-circle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.share-circle.facebook{background:#4567ad}
.share-circle.x{background:#5ea7eb}
.share-circle.linkedin{background:#157eb9}
.share-circle.link{background:#3f3f3f}

/* FOOTER BLOG */
.site-footer{background:#73169b;padding:24px 0 20px}
.footer-contact-wrap{width:1020px;margin:0 auto;display:grid;grid-template-columns:1.3fr .9fr 1fr;align-items:center;gap:20px;color:#ead5f6}
.footer-contact-block h3{font-size:30px;font-weight:500;margin-bottom:16px}
.footer-contact-row,.footer-social-row{display:flex;align-items:center;gap:16px;color:#ead5f6}
.footer-circle{width:44px;height:44px;border-radius:50%;border:2px solid #c798df;display:flex;align-items:center;justify-content:center;font-size:24px}
.footer-social-block h4{font-size:16px;margin-bottom:10px}
.footer-social-row a{color:#fff;font-size:34px;line-height:1}
.footer-copy-block{text-align:right;font-size:14px;color:#ead5f6}

/* INNER */
.simple-inner{min-height:50vh;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center}
.simple-inner-content{text-align:center}
.simple-inner h1{font-size:52px;margin-bottom:10px}

/* SERVICIOS */
.services-page{
    background:#ececec;
    padding:0 0 38px;
}
.services-grid{
    width:100%;
}
.services-grid-2{
    display:grid;
    grid-template-columns:25.8% 25.4% 25.8% 23%;
    min-height:560px;
}
.service-image{
    position:relative;
    min-height:560px;
    background-size:cover;
    background-position:center;
    overflow:hidden;
}
.service-img-1{
    background:
        linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,0)),
        linear-gradient(145deg, #1264d3 0%, #0b55ba 100%);
}
.service-img-1::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(28deg, transparent 0 15%, #d12342 15% 34%, transparent 34% 37%, #39a7e1 37% 54%, transparent 54% 57%, #d12342 57% 77%, transparent 77%),
        linear-gradient(-25deg, transparent 0 13%, #3ec0f0 13% 28%, transparent 28% 31%, #d12342 31% 46%, transparent 46% 49%, #3ec0f0 49% 66%, transparent 66% 69%, #d12342 69% 85%, transparent 85%);
    opacity:.95;
}
.service-img-1::after{
    content:"iplan";
    position:absolute;
    color:#ffffff;
    font-size:68px;
    font-weight:800;
    left:11%;
    top:14%;
    text-shadow:0 2px 6px rgba(0,0,0,.15);
    opacity:.92;
}
.service-img-2{
    background:
        linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,0)),
        linear-gradient(180deg, #d9d9df 0%, #9b9aa1 42%, #3f3b40 100%);
}
.service-img-2::before{
    content:"";
    position:absolute;
    left:50%;
    top:13%;
    width:34%;
    height:62%;
    transform:translateX(-50%) rotate(16deg);
    background:
        linear-gradient(180deg, #ffffff 0 10%, #111 10% 14%, #f4f4f4 14% 100%);
    border-radius:28px;
    box-shadow:0 14px 34px rgba(0,0,0,.25);
}
.service-img-2::after{
    content:"";
    position:absolute;
    left:50%;
    top:26%;
    width:22%;
    height:34%;
    transform:translateX(-50%) rotate(16deg);
    background:
        linear-gradient(180deg,
            #83c3e8 0 18%,
            #94d85e 18% 34%,
            #51a8dd 34% 52%,
            #9cd25f 52% 70%,
            #3f89be 70% 100%);
    border-radius:8px;
    box-shadow:inset 0 0 0 8px rgba(255,255,255,.35);
}
.service-text{
    background:#7a179f;
    color:#ffffff;
    min-height:560px;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
}
.service-text-left{
    padding:46px 32px 40px 32px;
}
.service-text-right{
    padding:40px 36px 40px 38px;
}
.service-text h2{
    font-size:59px;
    line-height:1.02;
    font-weight:800;
    margin-bottom:86px;
    color:#ffffff;
}
.service-text-right h2{
    font-size:32px;
    line-height:1.08;
    margin-bottom:64px;
}
.service-text p{
    font-size:20px;
    line-height:1.38;
    color:#f1e6f7;
    max-width:420px;
}
.service-text-left p{
    max-width:310px;
}
.service-text-right p{
    max-width:300px;
}
.service-text a{
    margin-top:auto;
    align-self:center;
    color:#f0d26a;
    font-size:21px;
    font-style:italic;
}

/* ONE PAGE */
.onepage-anchor{
    scroll-margin-top:124px;
}
.portfolio-preview-band{
    width:100%;
    background:var(--yellow);
    text-align:center;
    padding:78px 0 84px;
}
.portfolio-band-inner h2{
    color:var(--purple);
    font-size:58px;
    line-height:1;
    font-weight:800;
    margin-bottom:17px;
}
.tienda-section{
    background:#f2d400;
    padding:90px 20px 110px;
    text-align:center;
}
.tienda-inner h2{
    color:#6a2f81;
    font-size:48px;
    margin-bottom:16px;
}
.tienda-inner p{
    color:#6a2f81;
    font-size:22px;
}

/* PORTAFOLIO */
.brand-page{
    position:relative;
    background:linear-gradient(180deg,#ddd3ef 0%, #cfd9ec 100%);
    padding:0 0 90px;
    overflow:hidden;
}
.brand-page::before{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:0;
    width:90px;
    background:linear-gradient(180deg,#7b2e95 0%, #5f2b80 100%);
}
.brand-page::after{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    right:0;
    width:90px;
    background:linear-gradient(180deg,#7b2e95 0%, #5f2b80 100%);
}
.brand-hero{
    position:relative;
    z-index:2;
    width:1120px;
    max-width:calc(100% - 140px);
    margin:0 auto;
    padding-top:24px;
}
.brand-hero h1{
    background:var(--purple-dark);
    color:var(--yellow);
    text-align:center;
    font-size:44px;
    line-height:1;
    padding:14px 24px 12px;
    font-weight:800;
    letter-spacing:.02em;
}
.identity-grid{
    position:relative;
    z-index:2;
    width:1120px;
    max-width:calc(100% - 140px);
    margin:44px auto 0;
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:34px 36px;
}
.identity-item{
    display:flex;
    flex-direction:column;
    align-items:center;
}
.brand-circle{
    width:100%;
    max-width:280px;
    height:280px;
    border-radius:50%;
    border:8px solid #ffffff;
    box-shadow:0 18px 38px rgba(54,25,77,.16);
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    position:relative;
    overflow:hidden;
    background:#fff;
}
.brand-card{
    width:100%;
    max-width:280px;
    margin-top:16px;
    background:#f6f0ec;
    padding:18px 18px 16px;
    text-align:center;
    box-shadow:0 10px 24px rgba(56,27,65,.10);
}
.brand-card h3{
    color:var(--purple-dark);
    font-size:24px;
    line-height:1.05;
    font-weight:800;
    margin-bottom:12px;
}
.brand-card p{
    color:#7b4578;
    font-size:14px;
    line-height:1.38;
}

/* LOGOS */
.logo-iplay{
    background:radial-gradient(circle at 50% 50%, #fff 0 41%, #2577be 42% 100%);
}
.logo-iplay::before{
    content:"";
    position:absolute;
    left:18px;
    top:18px;
    width:42px;
    height:42px;
    border-radius:50%;
    background:#65bb47;
    box-shadow:58px 0 0 #f0df19, 0 55px 0 #38c0ea;
    opacity:.98;
}
.logo-iplay-text{
    position:relative;
    font-size:86px;
    line-height:.9;
    font-weight:800;
    color:#ee3f43;
    letter-spacing:-.06em;
}
.logo-iplay-text span{font-weight:700}
.logo-iplay-sub{
    position:absolute;
    bottom:48px;
    font-size:21px;
    color:#2f79b7;
    font-weight:500;
}
.logo-malva{
    background:linear-gradient(135deg,#ffffff 0 42%, #7a131d 42% 76%, #ede6de 76% 100%);
}
.logo-malva::before{
    content:"";
    position:absolute;
    right:38px;
    top:18px;
    width:78px;
    height:170px;
    background:linear-gradient(180deg,#c59b6d 0,#8e6033 100%);
    clip-path:polygon(50% 0, 64% 8%, 55% 42%, 84% 100%, 69% 100%, 50% 50%, 31% 100%, 16% 100%, 45% 42%, 36% 8%);
    opacity:.9;
}
.logo-malva-main{
    position:absolute;
    left:28px;
    top:76px;
    color:#fff;
    font-size:52px;
    letter-spacing:.02em;
}
.logo-malva-sub{
    position:absolute;
    left:26px;
    top:128px;
    width:120px;
    color:#fff;
    font-size:11px;
    line-height:1.1;
    text-align:left;
}
.logo-saluna{background:#0d67bc}
.logo-saluna-main{
    color:#d8e951;
    font-size:64px;
    font-style:italic;
    line-height:1;
}
.logo-saluna-sub{
    position:absolute;
    bottom:48px;
    color:#f2f2d8;
    font-size:14px;
}
.logo-lt{background:#3f6ea8}
.logo-lt-main{
    color:#e3de35;
    font-size:82px;
    font-style:italic;
    line-height:1;
}
.logo-lt-sub{
    position:absolute;
    bottom:42px;
    color:#fff;
    font-size:25px;
}
.logo-world{background:#0f96d1}
.logo-world-main{
    color:#a7cb2f;
    font-size:60px;
    font-weight:800;
    line-height:.95;
}
.logo-world-sub{
    color:#2f6db4;
    font-size:54px;
    font-weight:800;
    line-height:.95;
}
.logo-ve{
    background:#cab6ea;
    box-shadow:inset 0 0 0 16px #7c34a3;
}
.logo-ve::before{
    content:"";
    position:absolute;
    left:-6px;
    right:-6px;
    bottom:-8px;
    height:74px;
    background:#eb0b8d;
    border-radius:0 0 120px 120px/0 0 70px 70px;
}
.logo-ve-main{
    position:relative;
    z-index:2;
    color:#fff;
    font-style:italic;
    font-size:92px;
    line-height:1;
}

/* PORTAFOLIO 3 PANTALLAS */
.portfolio-dots{
    position:sticky;
    top:132px;
    z-index:30;
    width:100%;
    display:flex;
    justify-content:center;
    gap:14px;
    padding:18px 0 8px;
    background:linear-gradient(180deg, rgba(221,211,239,.96) 0%, rgba(221,211,239,.72) 100%);
}
.portfolio-dot{
    width:15px;
    height:15px;
    border-radius:50%;
    background:#d8c7e8;
    border:2px solid #6a2f81;
    display:inline-block;
    transition:transform .2s ease, background .2s ease;
}
.portfolio-dot:hover,
.portfolio-dot.active{
    background:#6a2f81;
    transform:scale(1.08);
}
.portfolio-screens{
    position:relative;
}
.portfolio-screen{
    min-height:100vh;
    padding:12px 0 90px;
    scroll-margin-top:124px;
}
.portfolio-screen-alt{
    background:linear-gradient(180deg,#ded4ef 0%, #e9edf6 100%);
    position:relative;
    overflow:hidden;
}
.portfolio-screen-alt::before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    bottom:0;
    width:90px;
    background:linear-gradient(180deg,#7b2e95 0%, #5f2b80 100%);
}
.portfolio-screen-alt::after{
    content:"";
    position:absolute;
    right:0;
    top:0;
    bottom:0;
    width:90px;
    background:linear-gradient(180deg,#7b2e95 0%, #5f2b80 100%);
}
.portfolio-screen-alt-2{
    background:linear-gradient(180deg,#d7dff0 0%, #efe4ec 100%);
    position:relative;
    overflow:hidden;
}
.portfolio-screen-alt-2::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255,255,255,.25) 0 14%, transparent 15%),
        radial-gradient(circle at 80% 28%, rgba(123,46,149,.10) 0 18%, transparent 19%),
        radial-gradient(circle at 50% 70%, rgba(255,209,0,.12) 0 16%, transparent 17%);
    pointer-events:none;
}
.portfolio-editorial-grid{
    position:relative;
    z-index:2;
    width:1120px;
    max-width:calc(100% - 140px);
    margin:44px auto 0;
    display:grid;
    grid-template-columns:1.15fr .85fr .85fr;
    gap:28px;
    align-items:start;
}
.editorial-piece{
    display:flex;
    flex-direction:column;
    gap:16px;
}
.editorial-piece-tall .editorial-art{
    min-height:520px;
}
.editorial-art{
    position:relative;
    min-height:250px;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 16px 34px rgba(45,20,66,.12);
}
.editorial-art-instagram-1{
    background:
        linear-gradient(180deg, rgba(255,255,255,.20), rgba(255,255,255,0)),
        linear-gradient(135deg,#7a189f 0%, #ed4ba6 42%, #ffcc33 100%);
}
.editorial-art-instagram-1::before{
    content:"";
    position:absolute;
    inset:22px;
    border-radius:18px;
    background:linear-gradient(180deg,#ffffff 0 15%, #f2f2f2 15% 100%);
    box-shadow:0 12px 22px rgba(0,0,0,.12);
}
.editorial-art-instagram-1::after{
    content:"SOCIAL";
    position:absolute;
    right:34px;
    bottom:36px;
    color:#7a189f;
    font-size:54px;
    font-weight:800;
    letter-spacing:.04em;
}
.editorial-art-instagram-2{
    background:linear-gradient(135deg,#f1d400 0%, #f7c66c 48%, #d74c97 100%);
}
.editorial-art-instagram-2::before{
    content:"";
    position:absolute;
    inset:18px;
    border-radius:14px;
    background:
        repeating-linear-gradient(
            180deg,
            rgba(255,255,255,.95) 0 44px,
            rgba(122,24,159,.08) 44px 88px
        );
}
.editorial-art-instagram-2::after{
    content:"Feed";
    position:absolute;
    left:24px;
    bottom:18px;
    color:#6a2f81;
    font-size:38px;
    font-weight:800;
}
.editorial-art-instagram-3{
    background:linear-gradient(135deg,#6c79d8 0%, #95d4e1 100%);
}
.editorial-art-instagram-3::before{
    content:"";
    position:absolute;
    left:50%;
    top:14%;
    width:48%;
    height:70%;
    transform:translateX(-50%) rotate(-8deg);
    background:linear-gradient(180deg,#ffffff 0 14%, #f4f4f4 14% 100%);
    border-radius:18px;
    box-shadow:0 14px 24px rgba(0,0,0,.14);
}
.editorial-art-instagram-3::after{
    content:"Story";
    position:absolute;
    right:20px;
    bottom:18px;
    color:#ffffff;
    font-size:34px;
    font-weight:800;
}
.editorial-card{
    background:#f6f0ec;
    padding:18px 18px 16px;
    box-shadow:0 10px 24px rgba(56,27,65,.10);
}
.editorial-card h3{
    color:var(--purple-dark);
    font-size:24px;
    line-height:1.05;
    font-weight:800;
    margin-bottom:12px;
}
.editorial-card p{
    color:#7b4578;
    font-size:14px;
    line-height:1.38;
}
.editorial-label{
    position:absolute;
    left:16px;
    bottom:14px;
    background:rgba(255,255,255,.88);
    color:#7d3b8f;
    font-size:12px;
    font-weight:700;
    padding:8px 10px;
    border-radius:4px;
    z-index:3;
}
.portfolio-showcase-grid{
    position:relative;
    z-index:2;
    width:1120px;
    max-width:calc(100% - 140px);
    margin:44px auto 0;
    display:grid;
    grid-template-columns:1.25fr .85fr .85fr;
    gap:28px;
    align-items:start;
}
.showcase-wide{
    min-height:100%;
}
.showcase-art{
    position:relative;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 16px 34px rgba(45,20,66,.12);
}
.showcase-art-1{
    min-height:520px;
    background:linear-gradient(135deg,#833c97 0%, #a2b5e4 55%, #f5d56f 100%);
}
.showcase-art-1::before{
    content:"";
    position:absolute;
    inset:26px;
    background:
        linear-gradient(90deg, transparent 0 8%, rgba(255,255,255,.75) 8% 10%, transparent 10% 44%, rgba(255,255,255,.55) 44% 46%, transparent 46% 100%),
        radial-gradient(circle at 65% 38%, rgba(255,255,255,.28) 0 18%, transparent 19%);
}
.showcase-art-1::after{
    content:"VISUAL";
    position:absolute;
    right:28px;
    bottom:28px;
    color:#ffffff;
    font-size:58px;
    font-weight:800;
    letter-spacing:.05em;
}
.showcase-art-2{
    min-height:250px;
    background:linear-gradient(135deg,#f2d400 0%, #f6a96b 48%, #853b97 100%);
}
.showcase-art-2::before{
    content:"";
    position:absolute;
    inset:22px;
    border-radius:16px;
    background:linear-gradient(180deg,#ffffff 0 22%, #f3f3f3 22% 100%);
    box-shadow:0 12px 20px rgba(0,0,0,.12);
}
.showcase-art-3{
    min-height:250px;
    background:linear-gradient(135deg,#6a2f81 0%, #ad84c8 50%, #d5e6ee 100%);
}
.showcase-art-3::before{
    content:"";
    position:absolute;
    left:50%;
    top:18%;
    width:52%;
    height:62%;
    transform:translateX(-50%);
    background:linear-gradient(180deg,#fff 0 18%, #efefef 18% 100%);
    border-radius:14px;
    box-shadow:0 12px 20px rgba(0,0,0,.14);
}
.showcase-card{
    display:flex;
    flex-direction:column;
    gap:16px;
}

/* RESPONSIVE */
@media (max-width: 1400px){
    .hero-logo-right{left:auto;right:70px}
}

@media (max-width: 1200px){
    .services-grid-2{
        grid-template-columns:1fr 1fr;
    }
    .service-image,
    .service-text{
        min-height:420px;
    }
    .service-text h2{
        font-size:44px;
        margin-bottom:34px;
    }
    .service-text-right h2{
        font-size:34px;
    }
    .service-text p{
        font-size:18px;
    }
}

@media (max-width: 1100px){
    .topbar-inner,.blog-submenu,.blog-list,.footer-contact-wrap{
        width:calc(100% - 32px);
    }
    .blog-card{
        grid-template-columns:1fr;
    }
    .blog-card-image{
        min-height:280px;
    }
    .brand-hero,
    .identity-grid,
    .portfolio-editorial-grid,
    .portfolio-showcase-grid{
        max-width:calc(100% - 60px);
    }
    .portfolio-dots{
        top:126px;
    }
}

@media (max-width: 1024px){
    .topbar-inner{width:calc(100% - 24px)}
    .menu-toggle{display:block}
    .main-nav{
        display:none;
        left:auto;
        right:0;
        top:74px;
        flex-direction:column;
        width:280px;
        box-shadow:0 16px 30px rgba(0,0,0,.16);
        z-index:60;
    }
    .main-nav.active{display:flex}
    .main-nav a{
        width:100%;
        justify-content:flex-start;
        padding:14px 18px;
        border-right:none;
        border-bottom:1px solid rgba(106,47,129,.14);
    }
    .main-nav a.active::after{display:none}
    .hero-wix{height:auto;padding:0 0 48px}
    .hero-yellow-shape{height:138px;clip-path:polygon(0 0,100% 0,100% 30%,82% 30%,77% 42%,54% 40%,0 67%)}
    .hero-logo-right,.hero-photo,.hero-title,.hero-copy{position:relative;left:auto;top:auto;width:auto}
    .hero-logo-right{margin:10px 16px 8px auto;width:fit-content;right:auto}
    .hero-photo{margin:24px 16px 18px}
    .hero-title{margin:0 16px 24px}
    .hello{font-size:40px}
    .line{font-size:44px}
    .hero-copy{margin:0 16px;font-size:16px;line-height:1.38}
    .blog-submenu{gap:18px;overflow:auto;padding-bottom:8px}
    .blog-filter{white-space:nowrap}
    .footer-contact-wrap{grid-template-columns:1fr;gap:24px;text-align:center}
    .footer-contact-row,.footer-social-row{justify-content:center}
    .footer-copy-block{text-align:center}
    .brand-page::before,
    .brand-page::after,
    .portfolio-screen-alt::before,
    .portfolio-screen-alt::after{
        width:36px;
    }
    .brand-hero,
    .identity-grid,
    .portfolio-editorial-grid,
    .portfolio-showcase-grid{
        max-width:calc(100% - 32px);
    }
    .brand-hero h1{
        font-size:34px;
    }
    .identity-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:28px 22px;
    }
    .brand-circle{
        max-width:240px;
        height:240px;
    }
    .brand-card{
        max-width:240px;
    }
    .portfolio-editorial-grid{
        grid-template-columns:1fr 1fr;
    }
    .portfolio-showcase-grid{
        grid-template-columns:1fr 1fr;
    }
    .showcase-wide{
        grid-column:1 / -1;
    }
    .editorial-piece-tall{
        grid-column:1 / -1;
    }
    .editorial-piece-tall .editorial-art,
    .showcase-art-1{
        min-height:380px;
    }
}

@media (max-width: 768px){
    .services-grid-2{
        grid-template-columns:1fr;
    }
    .service-image{
        min-height:300px;
    }
    .service-text{
        min-height:auto;
        padding:32px 22px;
    }
    .service-text h2{
        font-size:36px;
        margin-bottom:26px;
    }
    .service-text-right h2{
        font-size:30px;
        margin-bottom:26px;
    }
    .service-text p{
        font-size:17px;
        max-width:none;
    }
    .service-text a{
        align-self:flex-start;
        margin-top:24px;
    }
    .portfolio-dots{
        top:118px;
        gap:12px;
    }
    .portfolio-editorial-grid,
    .portfolio-showcase-grid{
        grid-template-columns:1fr;
    }
    .editorial-piece-tall .editorial-art,
    .showcase-art-1{
        min-height:320px;
    }
    .editorial-art,
    .showcase-art-2,
    .showcase-art-3{
        min-height:220px;
    }
}

@media (max-width: 640px){
    body{
        padding-top:92px;
    }
    .topbar{
        height:92px;
    }
    .onepage-anchor,
    .portfolio-screen{
        scroll-margin-top:108px;
    }
    .logo-badge{width:74px;height:74px;top:10px}
    .logo-badge-inner{font-size:29px}
    .menu-toggle{top:22px}
    .hero-yellow-shape{height:120px;clip-path:polygon(0 0,100% 0,100% 27%,76% 27%,70% 38%,45% 37%,0 64%)}
    .brand-wordmark{font-size:30px}
    .brand-sub{font-size:12px;padding-left:46px}
    .photo-ring{width:145px;height:145px}
    .hello{font-size:29px}
    .line{font-size:35px}
    .portfolio-band-inner h2{font-size:36px}
    .blog-card-content{padding:18px}
    .blog-title{font-size:22px}
    .blog-excerpt{font-size:16px}
    .share-modal-box{min-width:0;width:calc(100% - 32px)}
    .brand-page::before,
    .brand-page::after{
        display:none;
    }
    .brand-hero,
    .identity-grid,
    .portfolio-editorial-grid,
    .portfolio-showcase-grid{
        max-width:calc(100% - 24px);
    }
    .brand-hero h1{
        font-size:28px;
        padding:10px 12px;
    }
    .identity-grid{
        grid-template-columns:1fr;
    }
    .brand-circle{
        max-width:220px;
        height:220px;
    }
    .brand-card{
        max-width:220px;
    }
    .portfolio-dots{
        top:102px;
        padding:14px 0 6px;
    }
    .portfolio-dot{
        width:13px;
        height:13px;
    }
    .editorial-art-instagram-1::after,
    .showcase-art-1::after{
        font-size:36px;
    }
    .editorial-art-instagram-2::after,
    .editorial-art-instagram-3::after{
        font-size:28px;
    }
}

/* ===== RESTAURAR PORTAFOLIO ORIGINAL LARGO ===== */

.brand-page{
    position:relative;
    background:
        linear-gradient(90deg, rgba(113,59,148,.85) 0%, rgba(113,59,148,.25) 11%, rgba(113,59,148,0) 18%, rgba(113,59,148,0) 82%, rgba(113,59,148,.25) 89%, rgba(113,59,148,.85) 100%),
        linear-gradient(135deg, #7f60d6 0%, #a8d8ea 22%, #6e7fe1 47%, #8fd2dc 72%, #6270d7 100%);
    overflow:hidden;
    padding:0 0 90px;
}

.brand-page::before{
    content:"";
    position:absolute;
    inset:64px 13% 0;
    background:
        linear-gradient(90deg, rgba(255,122,89,.95) 0 0.6%, transparent 0.6% 18%, rgba(255,255,255,.55) 18% 18.8%, transparent 18.8% 39%, rgba(149,66,255,.35) 39% 61%, transparent 61% 81%, rgba(255,255,255,.4) 81% 81.8%, transparent 81.8% 99.4%, rgba(79,171,255,.85) 99.4% 100%),
        radial-gradient(circle at 50% 40%, rgba(197,84,214,.22) 0 23%, transparent 24%),
        radial-gradient(circle at 50% 50%, rgba(255,255,255,.12) 0 46%, transparent 47%);
    opacity:.95;
    pointer-events:none;
}

.brand-hero{
    position:relative;
    z-index:2;
    width:1330px;
    max-width:calc(100% - 80px);
    margin:0 auto;
    padding-top:22px;
}

.brand-hero h1{
    background:var(--purple-dark);
    color:var(--yellow);
    text-align:center;
    font-size:46px;
    line-height:1;
    padding:12px 24px 10px;
    font-weight:800;
}

.identity-grid-long{
    position:relative;
    z-index:2;
    width:980px;
    max-width:calc(100% - 50px);
    margin:52px auto 0;
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:42px 56px;
}

.identity-item{
    display:flex;
    flex-direction:column;
    align-items:center;
}

.brand-circle{
    width:225px;
    height:225px;
    border-radius:50%;
    border:4px solid rgba(255,255,255,.92);
    box-shadow:0 10px 28px rgba(18,20,70,.18);
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    position:relative;
    overflow:hidden;
    background:#fff;
}

.brand-card{
    width:230px;
    margin-top:14px;
    background:#f0ebea;
    padding:18px 18px 16px;
    text-align:center;
    box-shadow:0 5px 18px rgba(56,27,65,.12);
}

.brand-card h3{
    color:var(--purple-dark);
    font-size:24px;
    line-height:1;
    font-weight:800;
    margin-bottom:12px;
}

.brand-card p{
    color:#7b4578;
    font-size:14px;
    line-height:1.35;
}

/* logos ya existentes */
.logo-iplay{
    background:radial-gradient(circle at 50% 50%, #fff 0 41%, #2577be 42% 100%);
}
.logo-iplay::before{
    content:"";
    position:absolute;
    left:16px;
    top:18px;
    width:42px;
    height:42px;
    border-radius:50%;
    background:#65bb47;
    box-shadow:58px 0 0 #f0df19, 0 55px 0 #38c0ea;
    opacity:.98;
}
.logo-iplay-text{
    position:relative;
    font-size:86px;
    line-height:.9;
    font-weight:800;
    color:#ee3f43;
    letter-spacing:-.06em;
    text-shadow:0 2px 0 rgba(255,255,255,.6);
}
.logo-iplay-text span{font-weight:700}
.logo-iplay-sub{
    position:absolute;
    bottom:44px;
    font-size:21px;
    color:#2f79b7;
    font-weight:500;
}

.logo-malva{
    background:linear-gradient(135deg,#ffffff 0 42%, #7a131d 42% 76%, #ede6de 76% 100%);
}
.logo-malva::before{
    content:"";
    position:absolute;
    right:38px;
    top:18px;
    width:78px;
    height:170px;
    background:linear-gradient(180deg,#c59b6d 0,#8e6033 100%);
    clip-path:polygon(50% 0, 64% 8%, 55% 42%, 84% 100%, 69% 100%, 50% 50%, 31% 100%, 16% 100%, 45% 42%, 36% 8%);
    opacity:.9;
}
.logo-malva-main{
    position:absolute;
    left:28px;
    top:76px;
    color:#fff;
    font-size:52px;
    letter-spacing:.02em;
}
.logo-malva-sub{
    position:absolute;
    left:26px;
    top:128px;
    width:120px;
    color:#fff;
    font-size:11px;
    line-height:1.1;
    text-align:left;
}

.logo-saluna{background:#0d67bc}
.logo-saluna-main{
    color:#d8e951;
    font-size:64px;
    font-style:italic;
    line-height:1;
}
.logo-saluna-sub{
    position:absolute;
    bottom:48px;
    color:#f2f2d8;
    font-size:14px;
}

.logo-lt{background:#3f6ea8}
.logo-lt-main{
    color:#e3de35;
    font-size:82px;
    font-style:italic;
    line-height:1;
}
.logo-lt-sub{
    position:absolute;
    bottom:42px;
    color:#fff;
    font-size:25px;
}

.logo-world{background:#0f96d1}
.logo-world-main{
    color:#a7cb2f;
    font-size:60px;
    font-weight:800;
    line-height:.95;
}
.logo-world-sub{
    color:#2f6db4;
    font-size:54px;
    font-weight:800;
    line-height:.95;
}

.logo-ve{
    background:#cab6ea;
    box-shadow:inset 0 0 0 16px #7c34a3;
}
.logo-ve::before{
    content:"";
    position:absolute;
    left:-6px;
    right:-6px;
    bottom:-8px;
    height:74px;
    background:#eb0b8d;
    border-radius:0 0 120px 120px/0 0 70px 70px;
}
.logo-ve-main{
    position:relative;
    z-index:2;
    color:#fff;
    font-style:italic;
    font-size:92px;
    line-height:1;
    text-shadow:0 2px 0 rgba(100,47,122,.15);
}

/* logos restaurados */
.logo-twinkeys{
    background:#14131b;
}
.logo-twinkeys-main{
    color:#ffffff;
    font-size:38px;
    font-style:italic;
    line-height:1;
}
.logo-twinkeys-main span{
    font-style:normal;
    font-weight:700;
}
.logo-twinkeys-sub{
    position:absolute;
    bottom:54px;
    color:#f2e8d9;
    font-size:18px;
}

.logo-outfitstime{
    background:#e13397;
}
.logo-outfitstime-main{
    color:#c8fff8;
    font-size:50px;
    font-style:italic;
    line-height:.95;
    text-shadow:0 2px 0 rgba(255,255,255,.18);
}
.logo-outfitstime-sub{
    position:absolute;
    bottom:46px;
    color:#d6fff6;
    font-size:44px;
    font-style:italic;
    line-height:1;
}

.logo-rosario{
    background:#ffffff;
}
.logo-rosario-main{
    color:#7c68a8;
    font-size:58px;
    font-style:italic;
    line-height:.9;
}
.logo-rosario-sub{
    color:#1289c6;
    font-size:54px;
    font-style:italic;
    line-height:.9;
}

.logo-mary{
    background:#9db3c6;
}
.logo-mary-main{
    color:#f5c6d8;
    font-size:56px;
    font-style:italic;
    line-height:.92;
}
.logo-mary-sub{
    color:#ffffff;
    font-size:44px;
    font-style:italic;
    line-height:.92;
}

.logo-fabiola{
    background:#f5f5f5;
}
.logo-fabiola-main{
    color:#d65843;
    font-size:54px;
    font-style:italic;
    line-height:.95;
}
.logo-fabiola-sub{
    color:#6dc6d6;
    font-size:40px;
    font-style:italic;
    line-height:.95;
}

.logo-nashimbi{
    background:#ffffff;
}
.logo-nashimbi-mark{
    position:absolute;
    top:48px;
    color:#d19f2f;
    font-size:48px;
    font-weight:700;
    text-transform:uppercase;
}
.logo-nashimbi-main{
    color:#173874;
    font-size:34px;
    font-weight:800;
    margin-top:46px;
}

.logo-moodwly{
    background:#18b9df;
}
.logo-moodwly::before{
    content:"";
    position:absolute;
    left:58px;
    top:26px;
    width:110px;
    height:120px;
    background:
        linear-gradient(135deg,#f6df1f 0 33%, transparent 33%),
        linear-gradient(135deg,#9b7fe1 0 33%, transparent 33%),
        linear-gradient(135deg,#f033c0 0 33%, transparent 33%);
    background-repeat:no-repeat;
    background-size:64px 64px, 64px 64px, 64px 64px;
    background-position:0 0, 16px 28px, 44px 6px;
    opacity:.95;
}
.logo-moodwly-main{
    position:relative;
    z-index:2;
    color:#ffffff;
    font-size:92px;
    font-weight:800;
    line-height:.8;
    margin-top:-8px;
}
.logo-moodwly-sub{
    position:absolute;
    bottom:48px;
    color:#f0dc23;
    font-size:34px;
    font-weight:800;
    line-height:1;
}
.logo-moodwly-mini{
    position:absolute;
    bottom:28px;
    color:#fff8b2;
    font-size:17px;
    font-style:italic;
}

.logo-yamila{
    background:#ffffff;
}
.logo-yamila-main{
    color:#111111;
    font-size:54px;
    font-style:italic;
    line-height:.95;
}
.logo-yamila-sub{
    position:absolute;
    bottom:62px;
    color:#a98d47;
    font-size:18px;
    letter-spacing:.04em;
}

@media (max-width: 1024px){
    .brand-hero h1{font-size:36px}
    .identity-grid-long{
        grid-template-columns:repeat(2,1fr);
        gap:34px 26px;
        max-width:calc(100% - 30px);
    }
}

@media (max-width: 700px){
    .identity-grid-long{
        grid-template-columns:1fr;
    }
    .brand-circle{
        width:210px;
        height:210px;
    }
    .brand-card{
        width:210px;
    }
    .brand-hero{
        max-width:calc(100% - 24px);
    }
    .brand-hero h1{
        font-size:29px;
        padding:10px 12px;
    }
}