Javier Rodriguez

Menu

FRM 01 Helpers Absolute Positioning

FRAMEWORK 2024-07-26

/****************************************************************************
*****************************************************************************
FRM 01 Helpers Absolute Positioning
FRAMEWORK 2024-07-26
*****************************************************************************
****************************************************************************/

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */ 
html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}


:root {
    --abs-edge_factor: -1.2;
}

*[class*="abs--"] { position: absolute; z-index: 5;  }
.abs--rt-gcw-edge, .abs--rt-gcw-plus-edge, .abs--rt-gcw-s-edge, .abs--rt-gcw-s-plus-edge, .abs--rt-gcw-m-edge, .abs--rt-gcw-m-plus-edge, .abs--rt-gcw-xl-edge, 
.abs--rb-gcw-edge, .abs--rb-gcw-plus-edge, .abs--rb-gcw-s-edge, .abs--rb-gcw-s-plus-edge, .abs--rb-gcw-m-edge, .abs--rb-gcw-m-plus-edge, .abs--rb-gcw-xl-edge,
.abs--lt-gcw-edge, .abs--lt-gcw-plus-edge, .abs--lt-gcw-s-edge, .abs--lt-gcw-s-plus-edge, .abs--lt-gcw-m-edge, .abs--lt-gcw-m-plus-edge, .abs--lt-gcw-xl-edge,
.abs--lb-gcw-edge, .abs--lb-gcw-plus-edge, .abs--lb-gcw-s-edge, .abs--lb-gcw-s-plus-edge, .abs--lb-gcw-m-edge, .abs--lb-gcw-m-plus-edge, .abs--lb-gcw-xl-edge { position: absolute; z-index: 15; }

/* Right Top */
.abs--rt                    { pointer-events: none; top:0;                                                    bottom: auto;       left:auto;      right: 0; }
.abs--rt-gcw                { pointer-events: none; top:0;                                                    bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-half) );       transform: translate(100%, 0); }
.abs--rt-gcw-s              { pointer-events: none; top:0;                                                    bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-s-half) );     transform: translate(100%, 0); }
.abs--rt-gcw-m              { pointer-events: none; top:0;                                                    bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-m-half) );     transform: translate(100%, 0); }
.abs--rt-gcw-xl             { pointer-events: none; top:0;                                                    bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-xl-half) );     transform: translate(100%, 0); }

.abs--rt-edge               { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;       left:auto;      right: 0; }
.abs--rt-gcw-edge           { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-half) );       transform: translate(100%, 0); }
.abs--rt-gcw-s-edge         { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-s-half) );     transform: translate(100%, 0); }
.abs--rt-gcw-m-edge         { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-m-half) );     transform: translate(100%, 0); }
.abs--rt-gcw-xl-edge        { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-xl-half) );     transform: translate(100%, 0); }

/* Right Center */
.abs--rc                    { pointer-events: none; top:50%;      bottom: auto;       left:auto;      right: 0;                                       transform: translateY(-50%); }
.abs--rc-gcw                { pointer-events: none; top:50%;      bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-half) );       transform: translate(100%,  -50%); }
.abs--rc-gcw-s              { pointer-events: none; top:50%;      bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-s-half) );     transform: translate(100%,  -50%); }
.abs--rc-gcw-m              { pointer-events: none; top:50%;      bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-m-half) );     transform: translate(100%,  -50%); }
.abs--rc-gcw-xl             { pointer-events: none; top:50%;      bottom: auto;       left:auto;      right: calc( 50% - var(--gcw-max-xl-half) );    transform: translate(100%,  -50%); }
 
/* Right Bottom */
.abs--rb                    { pointer-events: none; top: auto;    bottom: 0;      left:auto;      right: 0; }
.abs--rb-gcw                { pointer-events: none; top: auto;    bottom: 0;      left:auto;      right: calc( 50% - var(--gcw-max-half) );       transform: translate(100%, 0); }
.abs--rb-gcw-s              { pointer-events: none; top: auto;    bottom: 0;      left:auto;      right: calc( 50% - var(--gcw-max-s-half) );     transform: translate(100%, 0); }
.abs--rb-gcw-m              { pointer-events: none; top: auto;    bottom: 0;      left:auto;      right: calc( 50% - var(--gcw-max-m-half) );     transform: translate(100%, 0); }
.abs--rb-gcw-xl             { pointer-events: none; top: auto;    bottom: 0;      left:auto;      right: calc( 50% - var(--gcw-max-xl-half) );     transform: translate(100%, 0); }
    
.abs--rb-edge               { pointer-events: none; top: auto;    bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );    left:auto;      right: 0; }
.abs--rb-gcw-edge           { pointer-events: none; top: auto;    bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );    left:auto;      right: calc( 50% - var(--gcw-max-half) ); transform: translate(100%, 0); }
.abs--rb-gcw-s-edge         { pointer-events: none; top: auto;    bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );    left:auto;      right: calc( 50% - var(--gcw-max-s-half) ); transform: translate(100%, 0); }
.abs--rb-gcw-m-edge         { pointer-events: none; top: auto;    bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );    left:auto;      right: calc( 50% - var(--gcw-max-m-half) ); transform: translate(100%, 0); }
.abs--rb-gcw-xl-edge        { pointer-events: none; top: auto;    bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );    left:auto;      right: calc( 50% - var(--gcw-max-xl-half) ); transform: translate(100%, 0); }

/* Left Top */
.abs--lt                    { pointer-events: none; top:0;                                                    bottom: auto;   right:auto;     left: 0; }
.abs--lt-gcw                { pointer-events: none; top:0;                                                    bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-half) ); transform: translate(-100%, 0); }
.abs--lt-gcw-s              { pointer-events: none; top:0;                                                    bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-s-half) ); transform: translate(-100%, 0); }
.abs--lt-gcw-m              { pointer-events: none; top:0;                                                    bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-m-half) ); transform: translate(-100%, 0); }
.abs--lt-gcw-xl             { pointer-events: none; top:0;                                                    bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-xl-half) ); transform: translate(-100%, 0); }

.abs--lt-edge               { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;   right:auto;     left: 0; }
.abs--lt-gcw-edge           { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-half) ); transform: translate(-100%, 0); }
.abs--lt-gcw-s-edge         { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-s-half) ); transform: translate(-100%, 0); }
.abs--lt-gcw-m-edge         { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );     bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-m-half) ); transform: translate(-100%, 0); }
.abs--lt-gcw-xl-edge        { pointer-events: none; top: calc( var(--sp-feat) * var(--abs-edge_factor) );    bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-xl-half) ); transform: translate(-100%, 0); }

 
/* Left Center */
.abs--lc                    { pointer-events: none; top:50%;              bottom: auto;   right:auto;     left: 0;                                        transform: translateY(-50%); }
.abs--lc-gcw                { pointer-events: none; top:50%;              bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-half) );        transform: translate(-100%,  -50%); }
.abs--lc-gcw-s              { pointer-events: none; top:50%;              bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-s-half) );      transform: translate(-100%,  -50%); }
.abs--lc-gcw-m              { pointer-events: none; top:50%;              bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-m-half) );      transform: translate(-100%,  -50%); }
.abs--lc-gcw-xl             { pointer-events: none; top:50%;              bottom: auto;   right:auto;     left: calc( 50% - var(--gcw-max-xl-half) );      transform: translate(-100%,  -50%); }
 
/* Left Bottom */
.abs--lb                    { pointer-events: none; top:auto;     bottom: 0;                                                      right:auto;     left: 0; }
.abs--lb-gcw                { pointer-events: none; top:auto;     bottom: 0;                                                      right:auto;     left: calc( 50% - var(--gcw-max-half) ); transform: translate(-100%, 0); }
.abs--lb-gcw-s              { pointer-events: none; top:auto;     bottom: 0;                                                      right:auto;     left: calc( 50% - var(--gcw-max-s-half) ); transform: translate(-100%, 0); }
.abs--lb-gcw-m              { pointer-events: none; top:auto;     bottom: 0;                                                      right:auto;     left: calc( 50% - var(--gcw-max-m-half) ); transform: translate(-100%, 0); }
.abs--lb-gcw-xl             { pointer-events: none; top:auto;     bottom: 0;                                                      right:auto;     left: calc( 50% - var(--gcw-max-xl-half) ); transform: translate(-100%, 0); }

.abs--lb-edge               { pointer-events: none; top:auto;     bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );        right:auto;     left: 0; }   
.abs--lb-gcw-edge           { pointer-events: none; top:auto;     bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );        right:auto;     left: calc( 50% - var(--gcw-max-half) ); transform: translate(-100%, 0); }
.abs--lb-gcw-s-edge         { pointer-events: none; top:auto;     bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );        right:auto;     left: calc( 50% - var(--gcw-max-s-half) ); transform: translate(-100%, 0); }
.abs--lb-gcw-m-edge         { pointer-events: none; top:auto;     bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );        right:auto;     left: calc( 50% - var(--gcw-max-m-half) ); transform: translate(-100%, 0); }
.abs--lb-gcw-xl-edge        { pointer-events: none; top:auto;     bottom: calc( var(--sp-feat) * var(--abs-edge_factor) );       right:auto;     left: calc( 50% - var(--gcw-max-xl-half) ); transform: translate(-100%, 0); }
    

/* Absolute Image Sizes 
-----------------------------------------------*/
:root {
    --abssize: 300px;
    --abssize-m: 200px;
    --abssize-full: 460px;
    --abs_pull_factor: 1.5rem
}
    /* Tablet */
    @media screen and (min-width: 760px) and (max-width: 999px) {:root {
            --abssize: 300px;
            --abssize-m: 200px;
            --abssize-full: 460px;
        }
    }
    /* Laptop Med  */
    @media screen and (min-width: 1000px) and (max-width: 1299px) {
        :root {
            --abssize: 400px;
            --abssize-m: 350px;
            --abssize-full: 620px;
        }
    }

    /* Laptop Large  */
    @media screen and (min-width: 1300px) and (max-width: 1499px) { 
        :root {
            --abssize: 500px;
            --abssize-m: 400px;
            --abssize-full: 770px;
        }
    }

    
    /* Desktop Medium */
    @media screen and (min-width: 1500px) and (max-width: 1799px) {  
        :root {
            --abssize: 450px;
            --abssize-m: 320px;
            --abssize-full: 690px;
        }
    }

    /* Desktop */
   @media screen and (min-width: 1800px) and (max-width: 2199px) {  
        :root {
            --abssize: 550px;
            --abssize-m: 380px;
            --abssize-full: 850px;
        }
    }

    /* Desktop Extra Wide */
    @media screen and (min-width: 2200px) { 
        :root {
            --abssize: 650px;
            --abssize-m: 470px;
            --abssize-full: 1000px;
        }
    }

    .abssize { width: var(--abssize) !important; }
    .abssize-m { width: var(--abssize-m) !important; }
    .abssize-full { width: var(--abssize-full) !important; z-index: 2 !important}
    .abssize-200 { width: 200px; }
    *[class*="abs--r"].abspi  > :first-child { margin-left: calc( var(--abs_pull_factor) * -1 ); }
    *[class*="abs--r"].abspo > :first-child { margin-left: calc( var(--abs_pull_factor) * 1 ); }
    *[class*="abs--l"].abspi  > :first-child { margin-left: calc( var(--abs_pull_factor) * 1 ); }
    *[class*="abs--l"].abspo > :first-child { margin-left: calc( var(--abs_pull_factor) * -1 ); }