.infoimg{aspect-ratio:160 / 212;}
/*img[fetchpriority="high"]{aspect-ratio:320 / 212;}*/
.suggestion{border:1px solid #ccc;display:none;position:absolute;background:white;z-index:100;}
.defaultform{padding-bottom:20px;padding-top:20px;background-color:#f7f7f9;border-radius:5px;margin-bottom:20px;margin-top:20px;}
.defaultform label{}
.contenttable{background:#f2f3f5;float:left;width:100%;border-radius:4px;padding:20px;margin-bottom:15px;}
.list-group-item a{font-size:17px;}
.list-group-item a::before{color:#000;margin-right:8px;line-height:20px;position:absolute;left:6px;font-size:14px;content:"\203A";vertical-align:top;margin-right:5px;}
html {scroll-behavior:smooth;}
.infotable.table td:nth-child(1){width:30%;}
.infotable.table td:nth-child(2){width:70%;}
.chr{border-top: 1px solid #666666;}
#myInput{background-image:url('/css/searchicon.png');background-position:10px 12px;background-repeat:no-repeat;width:100%;font-size:16px;padding:12px 20px 12px 40px;border:1px solid #ddd;margin-bottom:12px;}
.category p{padding:15px;text-align:center;float:left;}
.category{padding-bottom:20px;padding-top:20px;}
.category a{padding:15px;width:100%;text-align:center;float:left;background-color:#F7FAFC;border:1px solid #dee2e6;border-radius:0.25rem;background-clip:padding-box;box-sizing:border-box;}
.category a span{font-size:18px;margin-bottom:10px;display:block;height:40px}
.mainpic{padding-bottom:20px;padding-top:20px;}
.numcomments{font-size:14px}
.col-xs-offset-1{margin-left:8.33333333%;}
.navbar-brand{padding-bottom:.3125rem;padding-top:1rem;padding-right:.3125rem;padding-left: .3125rem}
.navbar-brand>img{margin-right:5px;display:inline-block}
.social-links{padding-right:10px;}
.social-links:hover{text-decoration:none;}
.relatedbox p{padding:15px;text-align:center;float:left;}
.relatedbox{padding-bottom:20px;padding-top:20px;float:left;min-height:306px;width:100%}
.relatedbox .articleclass{padding:15px;width:100%;text-align:center;background-color:#F7FAFC;border:1px solid #dee2e6;border-radius:0.25rem;background-clip:padding-box;box-sizing:border-box;float:left;}
.relatedbox .articleclass span{font-size:18px;margin-bottom:10px;display:block;height:55px}
.relatedbox .readmore, .artbox .readmore{text-decoration:underline;text-decoration-color:#337ab7;width:100%;text-align:right;}
.relatedbox .img-responsive{display:inherit;}
h4{font-weight:600;padding-bottom:20px;padding-top:20px;}
.relatedart p{padding:15px;text-align:center;float:left;}
.relatedart{padding-bottom:20px;padding-top:20px;}
.relatedart .articleclass{padding:15px;width:100%;text-align:center;float:left;background-color:#F7FAFC;border:1px solid #dee2e6;border-radius:0.25rem;background-clip:padding-box;box-sizing:border-box;}
.relatedart .articleclass span{font-size:18px;margin-bottom:10px;display:block;height:70px}
.relatedart .readmore, .artbox .readmore{text-decoration:underline;text-decoration-color:#337ab7;width:100%;text-align:right;}
.divmiddle h2{margin-bottom:20px;}
.interest-div{padding-bottom:20px;padding-top:20px;}
.interest-list li{padding-bottom:10px;}
.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9;}
h3{padding-bottom:20px;}
.bggrey{background-color:#e9ecef;}
.ccontainer{padding-top:50px;padding-bottom:50px;content-visibility:auto}
.bg-success{background-color:#dff0d8;padding:15px;}
.bg-danger{background-color:#f2dede;padding:15px;}
.relproduct{background-color:#FAFAFA;padding:10px;margin-bottom:20px;float:left;margin-top:10px;}
.relproduct span{text-align:center;width:100%;float:left;color:#192B42;font-weight:bold;padding-bottom:10px;padding-top:10px;}
.relproduct span.pricespan{font-size:large;}
.externallink:after{content:"\e164";top:1px;display:inline-block;font-family:"Glyphicons Halflings";font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;margin-left:3px;}
.internallink:after{content:"\e144";top:1px;display:inline-block;font-family:"Glyphicons Halflings";font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;margin-left:3px;}
.internallink{font-weight:bold;text-decoration:underline;}
.rating{padding-top:10px;padding-bottom:10px;}
.breadcrumb li a span{color:#192B42;}
.wpcc-container{opacity:1}.wpcc-transparency-5{opacity:.95}.wpcc-transparency-10{opacity:.9}.wpcc-transparency-15{opacity:.85}.wpcc-transparency-20{opacity:.8}.wpcc-transparency-25{opacity:.75}.wpcc-container{border-style:solid;border-width:0;box-sizing:border-box;display:flex;flex-wrap:nowrap;font-family:inherit;font-size:16px;line-height:1.5em;-webkit-transition:opacity 1s ease;-moz-transition:opacity 1s ease;-ms-transition:opacity 1s ease;-o-transition:opacity 1s ease;overflow:hidden;position:fixed;transition:opacity 1s ease;z-index:9999}@media print{.wpcc-container{display:none}}.wpcc-pushdown-wrap{max-height:0;overflow:hidden;-webkit-transition:max-height 1s;-moz-transition:max-height 1s;-ms-transition:max-height 1s;-o-transition:max-height 1s;transition:max-height 1s}.wpcc-pushdown{margin:0!important;position:static}.wpcc-invisible{opacity:0}.wpcc-fontsize-tiny{font-size:12px}.wpcc-fontsize-small{font-size:14px}.wpcc-fontsize-large{font-size:18px}.wpcc-border-thin{border-width:1px}.wpcc-border-normal{border-width:3px}.wpcc-border-thick{border-width:5px}.wpcc-float{flex-direction:column;max-width:22em;padding:1.5em}.wpcc-float.wpcc-padding-small{padding:1em}.wpcc-float.wpcc-padding-large{padding:2em}.wpcc-banner{flex-direction:row;margin:1em;padding:1em}.wpcc-banner.wpcc-padding-small{padding:.5em .5em .5em 1em}.wpcc-banner.wpcc-padding-large{padding:1.5em}.wpcc-banner.wpcc-margin-none{margin:0}.wpcc-banner.wpcc-margin-small{margin:.5em}.wpcc-banner.wpcc-margin-large{margin:1.5em}.wpcc-padding-none{padding:0}.wpcc-padding-none.wpcc-float .wpcc-message{margin:1em}.wpcc-padding-none.wpcc-banner .wpcc-message{margin:.8em 1em}.wpcc-padding-none.wpcc-banner .wpcc-btn{height:100%;padding:.9em 1.5em}.wpcc-btn,.wpcc-privacy{cursor:pointer}.wpcc-privacy{display:inline-block;opacity:.85;text-decoration:underline}.wpcc-privacy:hover{opacity:1}.wpcc-privacy:active,.wpcc-privacy:visited{color:initial}.wpcc-btn{display:block;font-size:.9em;font-weight:700;padding:.4em .8em;text-align:center;white-space:nowrap;-webkit-transition:background-color .2s ease;-moz-transition:background-color .2s ease;-ms-transition:background-color .2s ease;-o-transition:background-color .2s ease}.wpcc-btn:hover{text-decoration:none}.wpcc-top{top:1em}.wpcc-top.wpcc-margin-none{top:0}.wpcc-top.wpcc-margin-small{top:.5em}.wpcc-top.wpcc-margin-large{top:1.5em}.wpcc-left{left:1em}.wpcc-left.wpcc-margin-none{left:0}.wpcc-left.wpcc-margin-small{left:.5em}.wpcc-left.wpcc-margin-large{left:1.5em}.wpcc-right{right:1em}.wpcc-right.wpcc-margin-none{right:0}.wpcc-right.wpcc-margin-small{right:.5em}.wpcc-right.wpcc-margin-large{right:1.5em}.wpcc-bottom{bottom:1em}.wpcc-bottom.wpcc-margin-none{bottom:0}.wpcc-bottom.wpcc-margin-small{bottom:.5em}.wpcc-bottom.wpcc-margin-large{bottom:1.5em}.wpcc-float .wpcc-message{display:block;margin-bottom:1em}.wpcc-banner{align-items:center}.wpcc-banner.wpcc-top{left:0;right:0;top:0}.wpcc-banner.wpcc-bottom{left:0;right:0;bottom:0}.wpcc-banner .wpcc-message{display:block;flex:1 1 auto;margin-right:1em;max-width:100%}.wpcc-float .wpcc-compliance{flex:1 0 auto}.wpcc-corners-small{border-radius:5px}.wpcc-corners-normal{border-radius:7px}.wpcc-corners-large{border-radius:10px}.wpcc-corners-round .wpcc-btn{border-radius:4px}.wpcc-corners-round.wpcc-margin-none,.wpcc-corners-round.wpcc-padding-none .wpcc-btn{border-radius:0}.wpcc-corners-round.wpcc-margin-none{border-radius:0}@media screen and (max-width:414px) and (orientation:portrait),screen and (max-width:736px) and (orientation:landscape){.wpcc-top{top:0!important}.wpcc-bottom{bottom:0!important}.wpcc-banner,.wpcc-float,.wpcc-left,.wpcc-right{left:0!important;margin:0!important;right:0!important}.wpcc-banner{align-items:unset;flex-direction:column}.wpcc-corners-round{border-radius:0!important}.wpcc-float{max-width:none}.wpcc-message{margin-bottom:1em}.wpcc-banner.wpcc-padding-small{padding:.5em}.wpcc-padding-small .wpcc-message{margin-bottom:.5em}}
.accesorio{margin-bottom:10px;margin-top:10px;padding:20px;}
.accesorio a span,.deviceli a span{padding-bottom:10px;padding-top:10px;float:left;text-align:center;width:100%;height:4em;}
.adsblock{min-height:280px;padding-bottom:20px;padding-top:20px;}
.stepp{margin-top:20px;content-visibility:auto;border-top:1px solid #d3d3d3;padding-top:20px;}
.stepname{font-size:1.5em;font-weight:bold;margin-bottom:10px;width:100%;float:left;}
.drpdwn{width: 100%;margin-bottom:20px;}
.drpdwn .btn{display:block;margin-right:auto;margin-left:auto !important;float:none;}    
.dcompare{min-height:242px;max-height:242px;}
.devicecompare p{margin-top:10px;}
.deviceli{/*min-height:240px;*/margin-bottom:10px;margin-top:10px;}
#barraaceptacion{display:none;position:fixed;left:0px;right:0px;bottom:0px;padding-bottom:20px;width:100%;text-align:center;min-height:40px;background-color:rgba(0,0,0,0.5);color:#fff;z-index:99999;}
.inner{width:100%;position:absolute;padding-left:5px;font-family:verdana;font-size:12px;top:30%;}
.inner a.ok{padding:4px;color:#00ff2e;text-decoration:none;}
.inner a.info{padding-left:5px;text-decoration:none;color:#faff00;}
.btnno{float:left;margin-left:10px;}
.page-header{margin:20px 0 20px;}
.page-header h1{margin-top:0px;}
.barratop{margin-top:5px;margin-bottom:5px;color:white;}
.h2brand{font-size:18px;line-height:3rem;}
.topmenu{background-color:#192B42;}
.barratop a{color:white;}
.nav>li>a:focus, .nav>li>a:hover{color:#192B42;}
.navbar-toggle{background-color: white;}
.navbar-toggle .icon-bar{background-color:#192B42;}
.footer{background-color:#192B42;color:white;padding-top:10px;padding-bottom:10px;content-visibility:auto}
.footer a{color:white;}
.btn-info{background-color:#192B42;border-color:#192B42;}
.deviceclass{width:100%;text-align:center;float:left;margin-bottom:10px;color:#192B42;font-weight:bold;}
.brandli{margin-bottom:10px;}
.acctitle{font-size:18px;}
.divmiddle .row{margin-bottom:10px;}
p{margin-bottom:20px;margin-top:10px;}
.instructionimg{margin-bottom:10px;margin-top:10px;float: left;}
.instructionp{margin-bottom:10px;float: left;}
.instructionp span{margin-bottom:10px;}
.instrimg{margin-bottom:20px;margin-top:20px;}
.fab{width:64px;height:64px;border-radius:50%;text-align:center;color:#FFF;position:fixed;bottom:48px;right:35px;font-size:2.8667em;display:inline-block;cursor:default;}
.fab span{vertical-align:middle;}
.fab.child{right:58px;width:auto;height:auto;display:none;opacity:0;font-size:1.2em;}
.fab.child span{background:#337ab7;border-radius:10px;padding-left:10px;padding-right:10px;padding-top:5px;padding-bottom:5px;}
.fab.child a{color:white;}
.backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#ECECEC;opacity:0.9;display:none;}
#masterfab{background:#d9534f;box-shadow:0px 0px 3px rgba(0,0,0,0.5),3px 3px 3px rgba(0,0,0,0.25);}
.div_video{width:100%;height:480px;margin-bottom:30px;}
.div_video iframe{width:100%;height:480px;}
.description{/*float:left;*/width:100%;}
.txtd h2{margin-bottom:20px;}
.tools_name{font-size:18px;font-weight:700;margin:0 0 8px;color:#222;}
.tools_desc{font-size:15px;color:#555;margin:0;line-height:1.5;}
.tools_href{display:block;text-decoration:none;color:inherit;border:1px solid #e0e0e0;border-radius:8px;padding:20px;height:100%;transition:box-shadow .2s;}
.tools_img{height:auto;display:block;}
.tools_divimg{text-align:center;margin-bottom:14px;}
@media (min-width:768px){
.description p, .description ul li, .description ol li{font-size:15px;}
.description ul li, .description ol li{margin-bottom:5px;}
.txtd p{font-size:15px;}
.navleft{display:none;}
.accesorio img{padding-bottom:10px;}
.accesorio a{text-align:center;display:block;}
.sform input{height:40px;font-size:16px}
p, table td, table th, ul li, ol li{font-size:15px;line-height:2.5rem;}
}
@media (max-width:767px){
.artbox{border-bottom:1px solid #dee2e6}
.brandli{padding-bottom:15px;padding-top:15px;}
.brandli a{border:1px solid #dee2e6;padding:10px;}  
.defaultform label, .defaultform input{font-size:18px;}
.defaultform .form-control{height:40px;}
.suggestion{font-size:18px;width:90%;}
.category a{padding-right:10px;padding-left:10px;}
.category a span {height:60px;}
.numcomments{font-size:16px}
.h2brand{font-size:24px;line-height:4rem;}
.sform input{height:50px;font-size:18px}
h3{line-height:1.5;}
.relatedbox{margin-bottom:20px;margin-top:20px;background-color:#F7FAFC;border:1px solid #dee2e6;border-radius:0.25rem;background-clip:padding-box;box-sizing:border-box;padding:0}
.relatedbox .articleclass{background-color:none;border:0px;}
.relatedbox .articleclass span{height:70px}
.relatedart{margin-bottom:20px;margin-top:20px;background-color:#F7FAFC;border:1px solid #dee2e6;border-radius:0.25rem;background-clip:padding-box;box-sizing:border-box;}
.relatedart .articleclass{background-color:none;border:0px;}
.navleft .navbar-brand{color:white;}
.leftmenu .nav li a{color:white;}
.leftmenu .nav li{border-bottom:1px solid grey;}
.drpdwn{margin-top:20px;}
.accesorio{margin-bottom:10px;}
.accesorio img{padding-right:10px;}
/*.dropdown-menu>li>a{color:white;}*/
.contentdiv{display:flex;flex-direction:column;margin-bottom:20px;}
.contentdiv .artbox{padding-left:15px;padding-right:15px;}
.contentdiv .artbox div{background-color:#F7FAFC;border-left:1px solid #dee2e6;border-right:1px solid #dee2e6;border-radius:0.25rem;}
.leftmenu{order:4;background-color:#192B42;margin-bottom:20px;}
.divmiddle{order:0;}
p, table td, table th{font-size:18px;line-height:3rem;word-wrap:break-word;overflow-wrap:break-word;}
.div_video{position:relative;padding-bottom:56.25%;padding-top:25px;/*height:0;*/margin-bottom:20px;width:auto;}
.div_video iframe{position:absolute;top:0;left:0;width:100%;height:100%;}
/*.accesorio,.deviceli{border:1px solid grey;border-radius:5px;box-shadow:2px 2px 5px grey;}*/
.breadcrumb li{padding-top:10px;padding-bottom:10px;}
.footer ul li{padding-bottom:10px;}
div ul li, div ol li{font-size:18px;margin-bottom:10px;}
.interest-list li{padding-bottom:15px;}
.stepname{font-size:1.3em;}
.google-auto-placed{min-height:325px;}
.adsblock{min-height:320px;}
}
.row-flex{display:flex;flex-wrap:wrap;
  @for $i from 1 through 12 {
    [class*="col-xs-#{$i}"] {
      flex: $i 0 (100% / 12 * $i);
    }

    [class*="col-xs-#{$i}"]:last-child {
      flex: 0 0 (100% / 12 * $i);
    }
  }
  @media (min-width: 768px) {
    @for $i from 1 through 12 {
      [class*="col-sm-#{$i}"] {
        flex: $i 0 (100% / 12 * $i);
      }

      [class*="col-sm-#{$i}"]:last-child {
        flex: 0 0 (100% / 12 * $i);
      }
    }
  }
  @media (min-width: 992px) {
    @for $i from 1 through 12 {
      [class*="col-md-#{$i}"] {
        flex: $i 0 (100% / 12 * $i);
      }

      [class*="col-md-#{$i}"]:last-child {
        flex: 0 0 (100% / 12 * $i);
      }
    }
  }
  @media (min-width: 1200px) {
    @for $i from 1 through 12 {
      [class*="col-lg-#{$i}"] {
        flex: $i 0 (100% / 12 * $i);
      }

      [class*="col-lg-#{$i}"]:last-child {
        flex: 0 0 (100% / 12 * $i);
      }
    }
  }
}
.util-success-box{background:#dff0d8;border:1px solid #d6e9c6;color:#3c763d;padding:20px;border-radius:6px;margin-bottom:20px;}
.util-success-title{font-size:18px;font-weight:bold;margin-bottom:5px;}
.util-success-filename{margin-bottom:15px;font-size:14px;}
.util-error-box{background:#f2dede;border:1px solid #ebccd1;color:#a94442;padding:10px 15px;border-radius:4px;margin-bottom:15px;}
.util-download-btn{font-size:16px;padding:10px 30px;}
#drop-area{border:2px dashed #aaa;border-radius:8px;padding:30px 20px;text-align:center;background:#fafafa;cursor:pointer;transition:border-color .2s,background .2s;}
#error-box,#file-preview,#image-input,#scanner-panel,#result-panel,#qr-open-link,#bc-device-preview,#bc-results-content,#bc-confidence-badge,#bc-tip,#bc-degrad-controls,#bc-compare-section,#bc-compare-results{display:none;}
.util-drop-label{margin-bottom:8px;font-size:16px;}
#file-preview p{margin-bottom:8px;}
.util-browse-link{color:#337ab7;cursor:pointer;text-decoration:underline;}
.util-drop-hint{color:#888;font-size:13px;margin-bottom:4px;}
.util-drop-hint-last{color:#888;font-size:13px;margin:0;}
.util-file-name{word-break:break-all;}
.util-change-btn{font-size:13px;padding:4px 10px;}
.util-privacy-text{margin-top:20px;color:#888;font-size:13px;width:100%;float:left;}
.util-form-mt10{margin-top:10px;}
.util-form-mt15{margin-top:15px;}
.util-form-mt20{margin-top:20px;}
.util-form-control-md{max-width:300px;}
.util-form-control-lg{max-width:400px;}
.util-input-addon{padding:6px 10px;background:#eee;border:1px solid #ccc;border-right:0;border-radius:4px 0 0 4px;}
.util-input-rounded-right{border-radius:0 4px 4px 0;}
.util-start-btn{font-size:20px;padding:16px 40px;width:100%;max-width:400px;display:block;margin:0 auto;}
.util-reader-wrap{width:100%;max-width:500px;margin:0 auto;}
.util-panel-actions{text-align:center;margin-top:15px;}
.util-qr-result-label{font-weight:bold;margin-bottom:8px;}
.util-qr-result-text{word-break:break-all;font-size:15px;margin-bottom:12px;}
.util-qr-open-link{font-size:15px;padding:8px 20px;}
.util-radio-label{display:inline-block;}
.util-radio-label-mr{display:inline-block;margin-right:20px;}
.flash-wrap{padding:30px 0 20px;}
.flash-beam{width:0;height:0;border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:0 solid transparent;margin:0 auto 0;transition:border-bottom 0.4s ease,opacity 0.4s ease;opacity:0;}
.flash-beam-active{border-bottom:160px solid rgba(255,230,80,0.35);opacity:1;}
.flash-btn{width:130px;height:130px;border-radius:50%;border:4px solid #ccc;background:#f5f5f5;font-size:54px;line-height:1;cursor:pointer;transition:background 0.3s,border-color 0.3s,box-shadow 0.3s;display:inline-flex;align-items:center;justify-content:center;margin-top:10px;}
.flash-btn:disabled{opacity:0.5;cursor:not-allowed;}
.flash-btn-on{background:#fff8c0;border-color:#f0c040;box-shadow:0 0 30px 10px rgba(255,220,50,0.55);}
.flash-btn-off{background:#f5f5f5;border-color:#ccc;box-shadow:none;}
.flash-status{font-size:16px;font-weight:bold;margin-top:14px;}
.flash-status-on{color:#b8860b;}
.flash-status-off{color:#888;}
.flash-tip{font-size:13px;color:#888;margin-top:8px;}
.qr-fields{display:none;}
.qrread-vf-tl{top:0;left:0;border-width:2px 0 0 2px;border-radius:2px 0 0 0;}
.qrread-vf-tr{top:0;right:0;border-width:2px 2px 0 0;border-radius:0 2px 0 0;}
.qrread-vf-bl{bottom:0;left:0;border-width:0 0 2px 2px;border-radius:0 0 0 2px;}
.qrread-vf-br{bottom:0;right:0;border-width:0 2px 2px 0;border-radius:0 0 2px 0;}
.qrread-inner{position:relative;z-index:1;padding:26px 28px;background-color:black;float:left;}
.qrread-icon{float:left;width:160px;height:160px;border-radius:14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);margin-right:20px;position:relative;}
.qrread-icon-viewfinder{position:absolute;top:10px;left:10px;width:140px;height:140px;}
.qrread-icon-viewfinder-corner{position:absolute;width:10px;height:10px;border-color:#fff;border-style:solid;}
.qrread-icon-scanline{position:absolute;top:10px;left:14px;right:14px;height:2px;background:linear-gradient(90deg,transparent,#e74c3c,transparent);border-radius:1px;animation:qrscanline 2s ease-in-out infinite;}
@keyframes qrscanline{0%{top:140px;opacity:.4}50%{top:40px;opacity:1}100%{top:10px;opacity:.4}}
@media(max-width:767px){.qrread-inner{padding:20px 18px;}.qrread-icon{width:150px;height:150px;border-radius:12px;margin-right:14px;}.qrread-icon-viewfinder{top:7px;left:7px;width:136px;height:136px;}.qrread-icon-viewfinder-corner{width:9px;height:9px;}.qrread-icon-scanline{top:7px;left:11px;right:11px;}}
/* ── Generador de letras bonitas (fuentes) ───────────────────────── */
.fuentes-input{font-size:16px;width:100%;padding:12px 16px;border:2px solid #ccc;border-radius:6px;resize:vertical;min-height:80px;line-height:1.6;transition:border-color .2s;box-sizing:border-box;}
.fuentes-input:focus{border-color:#192b42;outline:none;box-shadow:0 0 0 2px rgba(25,43,66,.15);}
.fuentes-global-btns{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap;}
.fuentes-results-group{margin-bottom:8px;}
.fuentes-card{background:#f7f9fc;border:1px solid #e0e4ea;border-radius:8px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:center;gap:12px;}
.fuentes-card-name{font-size:11px;color:#777;display:block;margin-bottom:3px;text-transform:uppercase;letter-spacing:.4px;}
.fuentes-card-preview{flex:1;font-size:18px;word-break:break-all;line-height:1.5;min-width:0;}
.fuentes-copy-btn{flex-shrink:0;min-width:76px;text-align:center;transition:background-color .2s;}
.fuentes-copy-btn.copied{background-color:#28a745!important;border-color:#28a745!important;color:#fff!important;}
.fuentes-nick-card{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:10px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .15s;margin-bottom:6px;}
.fuentes-nick-card:hover{background:#e8f4fd;}
.fuentes-nick-preview{flex:1;font-size:16px;word-break:break-all;}
.fuentes-section-title{margin-top:24px;margin-bottom:10px;font-size:20px;font-weight:600;color:#192b42;border-bottom:2px solid #192b42;padding-bottom:5px;}
.fuentes-symbols-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;margin-bottom:4px;}
.fuentes-symbol-btn{display:inline-flex;align-items:center;justify-content:center;padding:5px 8px;font-size:18px;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;background:#fff;transition:background .15s,transform .1s;min-width:36px;min-height:36px;line-height:1;}
.fuentes-symbol-btn:hover{background:#e8f4fd;transform:scale(1.18);border-color:#192b42;z-index:1;position:relative;}
.fuentes-symbol-btn.copied-sym{background:#d4edda;border-color:#28a745;}
.fuentes-symbol-category{margin-top:14px;margin-bottom:4px;font-size:12px;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.5px;}
.fuentes-faq-item{border-bottom:1px solid #e0e4ea;padding:12px 0;}
.fuentes-faq-q{font-weight:600;font-size:15px;cursor:pointer;color:#192b42;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;user-select:none;}
.fuentes-faq-q::after{content:'+';font-size:20px;flex-shrink:0;color:#192b42;font-weight:400;line-height:1;margin-top:-2px;}
.fuentes-faq-item.open .fuentes-faq-q::after{content:'−';}
.fuentes-faq-a{display:none;margin-top:8px;font-size:15px;color:#444;line-height:1.65;}
.fuentes-faq-item.open .fuentes-faq-a{display:block;}
.fuentes-empty-state{text-align:center;color:#aaa;padding:18px 0;font-size:15px;}
.fuentes-nicks-grid{display:flex;flex-direction:column;gap:0;}
@media(max-width:767px){
  .fuentes-card{flex-direction:column;align-items:flex-start;}
  .fuentes-copy-btn{width:100%;}
  .fuentes-nick-card{flex-direction:column;align-items:flex-start;}
  .fuentes-nick-card .fuentes-copy-btn{width:100%;}
}
.exif-privacy-badge{display:flex;align-items:center;gap:10px;background:#e8f5e9;border:1px solid #c8e6c9;color:#2e7d32;padding:10px 14px;border-radius:6px;margin:12px 0 18px;font-size:14px;line-height:1.45;}
.exif-privacy-icon{font-size:20px;flex-shrink:0;}
.exif-error-box{display:none;background:#f2dede;border:1px solid #ebccd1;color:#a94442;padding:10px 15px;border-radius:4px;margin-bottom:15px;}
.exif-drop-zone{border:2px dashed #b3c2d4;border-radius:10px;padding:38px 20px;text-align:center;background:#f8fafc;cursor:pointer;transition:background .15s,border-color .15s;outline:none;}
.exif-drop-zone:hover,.exif-drop-zone:focus{background:#eef5fb;border-color:#5b8ec2;}
.exif-drop-zone-active{background:#e1efff;border-color:#337ab7;}
.exif-drop-zone-hidden{display:none;}
.exif-drop-icon{font-size:46px;margin-bottom:8px;}
.exif-drop-title{font-size:18px;font-weight:600;color:#192b42;margin:0 0 6px;}
.exif-drop-hint{color:#666;font-size:14px;margin:0 0 4px;}
.exif-drop-formats{color:#888;font-size:12px;margin:0 0 14px;}
.exif-file-input{display:none;}
.exif-browse-btn{padding:8px 22px;font-size:15px;}
.exif-loading{display:none;text-align:center;padding:30px 0;color:#555;}
.exif-spinner{display:inline-block;width:36px;height:36px;border:3px solid #d6e0ee;border-top-color:#337ab7;border-radius:50%;animation:exif-spin .8s linear infinite;margin-bottom:8px;}
@keyframes exif-spin{to{transform:rotate(360deg);}}
.exif-result-panel{display:none;margin-top:18px;}
.exif-result-header{display:flex;align-items:center;gap:14px;background:#f4f7fb;border:1px solid #e1e8f0;border-radius:8px;padding:12px;margin-bottom:14px;}
.exif-thumb-wrap{flex-shrink:0;width:96px;height:96px;border-radius:6px;overflow:hidden;background:#fff;border:1px solid #dde4ed;display:flex;align-items:center;justify-content:center;}
.exif-thumb{max-width:100%;max-height:100%;display:block;}
.exif-file-info{flex:1;min-width:0;}
.exif-file-name{font-weight:600;font-size:15px;color:#192b42;margin:0 0 4px;word-break:break-all;}
.exif-file-meta{font-size:13px;color:#7a8595;margin:0;}
.exif-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px;}
.exif-strip-btn[disabled]{opacity:.55;cursor:not-allowed;}
.exif-empty-msg{display:none;background:#fff8e1;border:1px solid #ffe082;color:#7c5e00;padding:14px;border-radius:6px;text-align:center;font-size:15px;margin-bottom:14px;}
.exif-disclaimer{margin-top:18px;color:#888;font-size:12px;font-style:italic;}
.exif-sections .panel{border-radius:6px;margin-bottom:8px;border:1px solid #dde4ed;}
.exif-panel-heading{padding:0;background:#f4f7fb;border-bottom:1px solid #dde4ed;}
.exif-panel-heading .panel-title{margin:0;}
.exif-panel-toggle{display:block;width:100%;text-align:left;background:transparent;border:0;padding:12px 14px;font-size:15px;font-weight:600;color:#192b42;cursor:pointer;}
.exif-panel-toggle:hover,.exif-panel-toggle:focus{background:#eaf2fa;outline:none;}
.exif-panel-caret{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #5b6b80;margin-right:6px;vertical-align:middle;transition:transform .15s;}
.exif-panel-toggle.collapsed .exif-panel-caret{transform:rotate(-90deg);}
.exif-panel-count{font-weight:400;color:#7a8595;font-size:13px;margin-left:4px;}
.exif-kv-table{margin-bottom:0;table-layout:fixed;width:100%;}
.exif-kv-table th{width:38%;background:#fafbfd;color:#3a4a60;font-weight:600;font-size:13px;word-break:break-word;}
.exif-kv-table td{font-size:14px;color:#192b42;word-break:break-word;}
.exif-section-empty{color:#aaa;font-style:italic;margin:8px 0 0;font-size:14px;}
.exif-map-actions{padding:10px 0 0;text-align:center;}
.exif-map-btn{font-size:14px;}
.exif-map-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:9999;padding:20px;}
.exif-map-modal.exif-map-open{display:flex;align-items:center;justify-content:center;}
body.exif-modal-open{overflow:hidden;}
.exif-map-dialog{background:#fff;border-radius:8px;width:100%;max-width:760px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;}
.exif-map-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #e1e8f0;}
.exif-map-title{margin:0;font-size:16px;color:#192b42;}
.exif-map-close{background:transparent;border:0;font-size:26px;line-height:1;color:#666;cursor:pointer;padding:0 6px;}
.exif-map-close:hover{color:#192b42;}
.exif-map-canvas{flex:1;min-height:380px;}
.exif-map-attr{margin:0;padding:6px 12px;font-size:11px;color:#888;background:#f8fafc;border-top:1px solid #e1e8f0;text-align:center;}
.exif-map-error{padding:30px;text-align:center;color:#a94442;}
@media(max-width:767px){
  .exif-result-header{flex-direction:column;align-items:flex-start;}
  .exif-thumb-wrap{width:100%;height:auto;max-height:160px;}
  .exif-thumb{max-height:160px;}
  .exif-actions .btn{width:100%;}
  .exif-kv-table th{width:42%;font-size:12px;}
  .exif-kv-table td{font-size:13px;}
  .exif-map-canvas{min-height:300px;}
}
.ttk-wrap{display:flex;justify-content:center;margin:20px 0;}
.ttk-facade,.ttk-active{position:relative;display:block;width:100%;max-width:325px;background:#000;border-radius:8px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;aspect-ratio:9/16;}
.ttk-facade{outline-offset:3px;}
.ttk-facade:focus-visible{outline:3px solid #5bc0de;}
.ttk-facade:focus{outline:3px solid #5bc0de;}
.ttk-active{cursor:default;aspect-ratio:9/16;}
@supports not (aspect-ratio: 9/16){
  .ttk-facade,.ttk-active{height:0;padding-bottom:177.78%;}
}
.ttk-thumb{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block;border:0;}
.ttk-thumb-fallback{background:linear-gradient(135deg,#1a1a1a 0%,#2a2a2a 100%);}
.ttk-overlay{position:absolute;left:0;right:0;bottom:0;padding:14px 14px 16px;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.45) 60%,rgba(0,0,0,0) 100%);color:#fff;pointer-events:none;display:flex;flex-direction:column;}
.ttk-author{font-weight:700;font-size:14px;margin-bottom:2px;text-shadow:0 1px 2px rgba(0,0,0,.6);}
.ttk-title{font-size:13px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.6);}
.ttk-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:flex;align-items:center;justify-content:center;transition:background .15s ease,transform .15s ease;}
.ttk-facade:hover .ttk-play,.ttk-facade:focus .ttk-play,.ttk-facade:focus-visible .ttk-play{background:rgba(255,32,80,.9);transform:translate(-50%,-50%) scale(1.06);}
.ttk-play svg{width:42px;height:42px;margin-left:4px;}
.ttk-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;display:block;}
.ttk-canonical{font-size:13px;color:#666;}
@media(min-width:768px){
  .ttk-facade,.ttk-active{max-width:400px;}
}
@media(min-width:992px){
  .ttk-facade,.ttk-active{max-width:480px;}
}
@media(min-width:1200px){
  .ttk-facade,.ttk-active{max-width:605px;}
}
.vib-status{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:20px;font-size:14px;font-weight:600;margin:8px 0 16px;background:#f5f5f5;border:1px solid #e0e0e0;color:#555;}
.vib-status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#bbb;margin-right:4px;flex-shrink:0;}
.vib-status-idle .vib-status-dot{background:#5bc0de;}
.vib-status-vibrating{background:#fff8e1;border-color:#ffe082;color:#8d6e00;}
.vib-status-vibrating .vib-status-dot{background:#ff9800;animation:vibPulse 0.4s ease-in-out infinite alternate;}
.vib-status-done{background:#e8f5e9;border-color:#c8e6c9;color:#2e7d32;}
.vib-status-done .vib-status-dot{background:#4caf50;}
.vib-status-error{background:#ffebee;border-color:#ffcdd2;color:#a94442;}
.vib-status-error .vib-status-dot{background:#a94442;}
@keyframes vibPulse{0%{transform:scale(0.8);opacity:0.6;}100%{transform:scale(1.4);opacity:1;}}
.vib-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px;}
.vib-btn{min-height:48px;min-width:48px;padding:12px 20px;font-size:15px;flex:1 1 auto;}
.vib-btn-primary{flex:1 1 100%;font-size:18px;font-weight:700;}
.vib-btn-stop{flex:1 1 100%;}
.vib-btn-disabled{opacity:0.5;cursor:not-allowed;}
.vib-inline-form{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;}
.vib-inline-form .form-control{flex:1 1 200px;min-height:44px;}
.vib-inline-form .vib-btn{flex:0 0 auto;}
.vib-help{font-size:13px;color:#666;margin-top:6px;}
.vib-help code{background:#f0f0f0;padding:1px 6px;border-radius:3px;font-size:12px;}
.vib-ios-block{margin:20px 0;}
.vib-ios-card{background:#fff8e1;border:1px solid #ffd54f;border-left:4px solid #ff9800;border-radius:6px;padding:18px 20px;}
.vib-ios-card h3{margin-top:0;color:#7a4f00;}
.vib-ios-card h4{color:#7a4f00;margin-top:14px;font-size:16px;}
.vib-haptic-block{margin-top:14px;padding-top:14px;border-top:1px dashed #ffcc80;}
.vib-haptic-switch{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;}
.vib-diag{margin:20px 0;background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;padding:12px 16px;}
.vib-diag summary{cursor:pointer;color:#192b42;outline-offset:2px;}
.vib-diag summary:focus-visible{outline:2px solid #5bc0de;}
.vib-diag-toggle{font-size:13px;color:#888;font-weight:normal;}
.vib-diag-table{width:100%;margin-top:12px;font-size:14px;}
.vib-diag-table th{text-align:left;width:42%;padding:6px 10px;color:#555;font-weight:600;border-bottom:1px solid #eee;}
.vib-diag-table td{padding:6px 10px;color:#333;border-bottom:1px solid #eee;font-family:monospace;}
.util-faq dt{font-weight:600;color:#192b42;margin-top:14px;font-size:15px;line-height:2.5rem}
.util-faq dd{margin-left:0;color:#444;font-size:15px;line-height:2.5rem}
.util-section-h{margin-top:18px;font-size:17px;color:#0f172a}
@media(max-width:767px){
  .vib-btn{flex:1 1 calc(50% - 5px);}
  .vib-btn-primary,.vib-btn-stop{flex:1 1 100%;}
  .vib-inline-form{flex-direction:column;align-items:stretch;}
  .vib-inline-form .form-control,.vib-inline-form .vib-btn{flex:1 1 auto;width:100%;}
  .vib-diag-table th{width:50%;font-size:13px;}
  .vib-diag-table td{font-size:13px;}
}
.audiorec-privacy-badge{background:#ecfdf5;border-left:3px solid #10b981;color:#065f46;padding:10px 14px;border-radius:4px;margin:12px 0;font-size:14px}
.audiorec-error-box{display:none;background:#fef2f2;border-left:3px solid #dc2626;color:#991b1b;padding:10px 14px;border-radius:4px;margin:12px 0;font-size:14px}
.audiorec-stage{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:24px;margin:20px 0}
.audiorec-status-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.audiorec-status-dot{display:inline-block;width:12px;height:12px;border-radius:50%;background:#cbd5e1;flex:0 0 auto}
.audiorec-status-dot-recording{background:#dc2626;box-shadow:0 0 0 0 rgba(220,38,38,.55);animation:audiorec-pulse 1.4s ease-out infinite}
.audiorec-status-dot-paused{background:#f59e0b}
.audiorec-status-dot-ready{background:#16a34a}
@keyframes audiorec-pulse{0%{box-shadow:0 0 0 0 rgba(220,38,38,.55)}70%{box-shadow:0 0 0 14px rgba(220,38,38,0)}100%{box-shadow:0 0 0 0 rgba(220,38,38,0)}}
.audiorec-status-label{font-weight:600;color:#0f172a;flex:1 1 auto}
.audiorec-timer{font-family:'Menlo','Consolas',monospace;font-size:20px;color:#0f172a;background:#fff;border:1px solid #e2e8f0;padding:4px 10px;border-radius:6px;letter-spacing:1px}
.audiorec-meter-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:6px;margin-bottom:18px}
.audiorec-meter{display:block;width:100%;height:80px}
.audiorec-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.audiorec-btn-record{display:inline-flex;align-items:center;gap:8px;font-weight:700;min-width:160px;justify-content:center}
.audiorec-btn-record.audiorec-btn-stop{background:#475569;border-color:#334155}
.audiorec-btn-record.audiorec-btn-stop:hover,.audiorec-btn-record.audiorec-btn-stop:focus{background:#334155;border-color:#1e293b}
.audiorec-rec-dot{width:10px;height:10px;border-radius:50%;background:#fff;display:inline-block}
.audiorec-btn-record.audiorec-btn-stop .audiorec-rec-dot{border-radius:2px}
.audiorec-btn-pause{min-width:110px}
.audiorec-preview-box{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:18px;margin-top:20px}
.audiorec-preview{display:block;width:100%;margin-bottom:14px}
.audiorec-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.audiorec-btn-action{font-weight:600;min-width:140px}
.audiorec-btn-discard{color:#64748b;text-decoration:underline;margin-left:auto}
.audiorec-btn-discard:hover,.audiorec-btn-discard:focus{color:#dc2626}
.audiorec-disclaimer{font-size:13px;color:#64748b;margin-top:14px;padding:10px;background:#f1f5f9;border-radius:4px}
.audiorec-privacy{font-size:13px;color:#64748b;margin-top:8px;font-style:italic}
@media(max-width:767px){
  .audiorec-stage{padding:16px}
  .audiorec-status-row{flex-wrap:wrap}
  .audiorec-timer{font-size:18px}
  .audiorec-btn-record,.audiorec-btn-pause,.audiorec-btn-action{flex:1 1 100%;min-width:0}
  .audiorec-btn-discard{flex:1 1 100%;text-align:center;margin-left:0}
}
.audiorec-banner{position:relative;overflow:hidden;border-radius:8px;margin:30px 0;box-shadow:0 6px 24px rgba(0,0,0,.2);background:linear-gradient(135deg,#1a0410 0%,#2d0820 50%,#1a0410 100%);border-bottom:3px solid #dc2626}
.audiorec-banner:before,.audiorec-banner:after{content:'';position:absolute;border-radius:50%;pointer-events:none}
.audiorec-banner:before{top:-50px;right:8%;width:180px;height:180px;background:rgba(220,38,38,.05)}
.audiorec-banner:after{bottom:-40px;left:10%;width:140px;height:140px;background:rgba(239,68,68,.04)}
.audiorec-inner{position:relative;z-index:1;padding:26px 28px}
.audiorec-icon{float:left;width:60px;height:60px;margin-right:20px;position:relative;border-radius:14px;background:rgba(220,38,38,.12);border:1px solid rgba(220,38,38,.22);display:flex;align-items:center;justify-content:center}
.audiorec-icon-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70px;height:70px;border-radius:50%;background:radial-gradient(circle,rgba(239,68,68,.18) 0%,transparent 70%)}
.audiorec-text{overflow:hidden;padding-right:10px}
.audiorec-text p.audiorec-label{margin:0 0 3px;font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.audiorec-label-text{color:rgba(255,255,255,.4)}
.audiorec-label-badge{display:inline-block;font-size:10px;padding:1px 7px;border-radius:3px;margin-left:8px;letter-spacing:.3px;background:rgba(220,38,38,.18);color:#fca5a5}
.audiorec-text h3{margin:0 0 5px;font-size:18px;font-weight:700;color:#fff;line-height:1.35}
.audiorec-text p.audiorec-desc{margin:0;font-size:13px;line-height:1.5;color:rgba(255,255,255,.62)}
.audiorec-text p.audiorec-desc strong{color:rgba(252,165,165,.95)}
.audiorec-cta{padding:0 28px 20px;position:relative;z-index:1}
.btn-audiorec{display:inline-block;color:#fff;font-size:14px;font-weight:700;padding:11px 24px;border-radius:8px;text-decoration:none;transition:all .25s ease;border:0;background:linear-gradient(145deg,#dc2626,#b91c1c);box-shadow:0 4px 14px rgba(220,38,38,.32)}
.btn-audiorec:hover,.btn-audiorec:focus{background:linear-gradient(145deg,#ef4444,#dc2626);box-shadow:0 6px 20px rgba(220,38,38,.45);color:#fff;text-decoration:none;transform:translateY(-1px)}
.audiorec-cta .btn-audiorec svg{vertical-align:middle;margin-left:6px;margin-top:-2px}
.audiorec-features{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.05);padding:12px 28px}
.audiorec-features span{display:inline-block;margin-right:18px;line-height:22px;font-size:13px;color:rgba(255,255,255,.88)}
.audiorec-features span svg{vertical-align:middle;margin-right:4px;margin-top:-1px;stroke:rgba(255,255,255,.3)}
@media(max-width:767px){
  .audiorec-inner{padding:20px 18px}
  .audiorec-cta{padding:0 18px 16px}
  .audiorec-features{padding:10px 18px}
  .audiorec-icon{width:50px;height:50px;border-radius:12px;margin-right:14px}
  .audiorec-text h3{font-size:16px}
  .audiorec-text p.audiorec-desc{font-size:13px}
  .audiorec-features span{display:block;margin-right:0;margin-bottom:2px}
}
.sens-privacy-badge{background:#ecfdf5;border-left:3px solid #10b981;color:#065f46;padding:10px 14px;border-radius:4px;margin:12px 0 18px;font-size:14px}
.sens-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:18px 20px;margin:0 0 20px;box-shadow:0 1px 3px rgba(15,23,42,.04);display:flex;flex-direction:column;height:100%}
.sens-card-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:8px}
.sens-card-title{margin:0;font-size:18px;color:#0f172a;line-height:1.3}
.sens-card-desc{color:#475569;font-size:14px;line-height:1.55;margin:0 0 14px}
.sens-status{display:inline-flex;align-items:center;padding:4px 12px;border-radius:14px;font-size:12px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;flex-shrink:0}
.sens-status-idle{background:#f1f5f9;color:#475569}
.sens-status-running{background:#dcfce7;color:#166534}
.sens-status-running:before{content:'';display:inline-block;width:7px;height:7px;border-radius:50%;background:#16a34a;margin-right:6px;animation:sens-pulse 1.4s ease-in-out infinite}
.sens-status-error{background:#fee2e2;color:#991b1b}
.sens-status-denied{background:#fef3c7;color:#92400e}
.sens-status-nodata{background:#fef9c3;color:#854d0e}
@keyframes sens-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
.sens-error{background:#fef2f2;border-left:3px solid #dc2626;color:#991b1b;padding:8px 12px;border-radius:4px;margin-bottom:12px;font-size:13px;line-height:1.45}
.sens-axes{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.sens-axis{display:grid;grid-template-columns:24px 1fr 70px 36px;align-items:center;gap:8px;font-size:14px}
.sens-axis-label{font-weight:700;color:#0f172a;font-family:'Menlo','Consolas',monospace}
.sens-bar-wrap{position:relative;display:block;height:14px;background:#f1f5f9;border-radius:7px;overflow:hidden}
.sens-bar-wrap:before{content:'';position:absolute;left:50%;top:0;bottom:0;width:1px;background:#cbd5e1;z-index:1}
.sens-bar{position:absolute;top:0;height:100%;width:0%;transition:width .12s linear;background:linear-gradient(90deg,#22c55e,#16a34a)}
.sens-bar-pos{left:50%}
.sens-bar-neg{right:50%;background:linear-gradient(270deg,#f59e0b,#dc2626)}
.sens-axis-value{font-family:'Menlo','Consolas',monospace;text-align:right;color:#0f172a;font-size:13px;font-variant-numeric:tabular-nums}
.sens-axis-unit{color:#64748b;font-size:12px}
.sens-light-bar-wrap{height:18px;margin-top:8px}
.sens-light-bar-wrap:before{display:none}
.sens-bar-light{left:0;width:0%;background:linear-gradient(90deg,#1e3a5f,#fbbf24,#fef3c7)}
.sens-light-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.sens-light-value{font-family:'Menlo','Consolas',monospace;font-size:28px;font-weight:700;color:#0f172a;font-variant-numeric:tabular-nums}
.sens-light-label{color:#64748b;font-size:14px;margin-left:auto;font-style:italic}
.sens-compass{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.sens-compass-rose{position:relative;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,#fff 0%,#f1f5f9 70%,#e2e8f0 100%);border:2px solid #cbd5e1;flex-shrink:0}
.sens-compass-needle{position:absolute;left:50%;top:50%;width:6px;height:50px;background:linear-gradient(180deg,#dc2626 0%,#dc2626 50%,#475569 50%,#475569 100%);transform:translate(-50%,-100%) rotate(0deg);transform-origin:50% 100%;transition:transform .15s ease-out;border-radius:3px;box-shadow:0 1px 2px rgba(0,0,0,.15)}
.sens-compass-mark{position:absolute;left:50%;top:50%;font-size:11px;font-weight:700;color:#475569;transform:translate(-50%,-50%)}
.sens-compass-n{top:8px;color:#dc2626}
.sens-compass-e{left:auto;right:6px;top:50%}
.sens-compass-s{top:auto;bottom:8px}
.sens-compass-w{left:6px;top:50%}
.sens-compass-info{flex:1 1 160px;min-width:0}
.sens-compass-heading{font-size:24px;font-family:'Menlo','Consolas',monospace;font-weight:700;color:#0f172a;margin-bottom:8px;line-height:1.2}
.sens-compass-card{display:inline-block;margin-left:6px;font-size:14px;background:#0f172a;color:#fff;padding:2px 10px;border-radius:8px;vertical-align:middle;font-weight:600}
.sens-compass-axes{display:grid;grid-template-columns:auto 1fr;gap:2px 8px;margin:0;font-size:13px;line-height:1.4}
.sens-compass-axes dt{color:#64748b;font-weight:600}
.sens-compass-axes dd{margin:0;color:#0f172a;font-family:'Menlo','Consolas',monospace;font-variant-numeric:tabular-nums}
.sens-gps{margin-bottom:14px}
.sens-gps-waiting{color:#64748b;font-style:italic;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:6px;padding:14px;text-align:center;margin:0}
.sens-gps-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;margin:0;font-size:13px}
.sens-gps-grid dt{color:#64748b;font-weight:600}
.sens-gps-grid dd{margin:0;color:#0f172a;font-family:'Menlo','Consolas',monospace;font-variant-numeric:tabular-nums;word-break:break-all}
.sens-btn{margin-top:auto;align-self:flex-start;min-width:140px;font-weight:600}
.sens-btn-disabled{opacity:.5;cursor:not-allowed}
@media(max-width:767px){
  .sens-card{padding:14px 14px}
  .sens-card-title{font-size:16px}
  .sens-axis{grid-template-columns:22px 1fr 60px 32px}
  .sens-light-value{font-size:24px}
  .sens-compass-rose{width:100px;height:100px}
  .sens-compass-needle{height:42px}
  .sens-btn{width:100%}
}
.sensorstest-banner{position:relative;overflow:hidden;border-radius:8px;margin:30px 0;box-shadow:0 6px 24px rgba(0,0,0,.2);background:linear-gradient(135deg,#041820 0%,#062734 50%,#041820 100%);border-bottom:3px solid #22d3ee}
.sensorstest-banner:before,.sensorstest-banner:after{content:'';position:absolute;border-radius:50%;pointer-events:none}
.sensorstest-banner:before{top:-50px;right:8%;width:180px;height:180px;background:rgba(34,211,238,.06)}
.sensorstest-banner:after{bottom:-40px;left:10%;width:140px;height:140px;background:rgba(167,139,250,.04)}
.sensorstest-inner{position:relative;z-index:1;padding:26px 28px}
.sensorstest-icon{float:left;width:60px;height:60px;margin-right:20px;position:relative;border-radius:14px;background:rgba(34,211,238,.10);border:1px solid rgba(34,211,238,.22);display:flex;align-items:center;justify-content:center;overflow:visible}
.sensorstest-icon-phone{width:22px;height:36px;border-radius:4px;background:#0e2a3a;border:1.6px solid #22d3ee;position:relative;z-index:2;box-shadow:0 0 12px rgba(34,211,238,.4)}
.sensorstest-icon-phone:before{content:'';position:absolute;top:3px;left:50%;transform:translateX(-50%);width:8px;height:1.4px;border-radius:1px;background:#22d3ee;opacity:.7}
.sensorstest-icon-phone:after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:6px;height:1.4px;border-radius:1px;background:#0891b2}
.sensorstest-icon-ring{position:absolute;top:50%;left:50%;border:1.6px solid #22d3ee;border-radius:50%;transform:translate(-50%,-50%);animation:sensorstest-ring 2.2s ease-out infinite;opacity:0}
.sensorstest-icon-ring-1{width:34px;height:34px;animation-delay:0s}
.sensorstest-icon-ring-2{width:46px;height:46px;animation-delay:.55s;border-color:#a78bfa}
.sensorstest-icon-ring-3{width:56px;height:56px;animation-delay:1.1s;border-color:#22d3ee;opacity:0}
@keyframes sensorstest-ring{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}40%{opacity:.7}100%{opacity:0;transform:translate(-50%,-50%) scale(1.1)}}
.sensorstest-text{overflow:hidden;padding-right:10px}
.sensorstest-text p.sensorstest-label{margin:0 0 3px;font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.sensorstest-label-text{color:rgba(255,255,255,.4)}
.sensorstest-label-badge{display:inline-block;font-size:10px;padding:1px 7px;border-radius:3px;margin-left:8px;letter-spacing:.3px;background:rgba(34,211,238,.16);color:#67e8f9}
.sensorstest-text h3{margin:0 0 5px;font-size:18px;font-weight:700;color:#fff;line-height:1.35}
.sensorstest-text p.sensorstest-desc{margin:0;font-size:13px;line-height:1.5;color:rgba(255,255,255,.65)}
.sensorstest-text p.sensorstest-desc strong{color:rgba(103,232,249,.95)}
.sensorstest-cta{padding:0 28px 20px;position:relative;z-index:1}
.btn-sensorstest{display:inline-block;color:#04222e;font-size:14px;font-weight:700;padding:11px 24px;border-radius:8px;text-decoration:none;transition:all .25s ease;border:0;background:linear-gradient(145deg,#22d3ee,#0891b2);box-shadow:0 4px 14px rgba(34,211,238,.32)}
.btn-sensorstest:hover,.btn-sensorstest:focus{background:linear-gradient(145deg,#67e8f9,#22d3ee);box-shadow:0 6px 20px rgba(34,211,238,.45);color:#04222e;text-decoration:none;transform:translateY(-1px)}
.sensorstest-cta .btn-sensorstest svg{vertical-align:middle;margin-left:6px;margin-top:-2px}
.sensorstest-features{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.05);padding:12px 28px}
.sensorstest-features span{display:inline-block;margin-right:18px;line-height:22px;font-size:13px;color:rgba(255,255,255,.88)}
.sensorstest-features span svg{vertical-align:middle;margin-right:4px;margin-top:-1px;stroke:rgba(34,211,238,.55)}
@media(max-width:767px){
  .sensorstest-inner{padding:20px 18px}
  .sensorstest-cta{padding:0 18px 16px}
  .sensorstest-features{padding:10px 18px}
  .sensorstest-icon{width:50px;height:50px;border-radius:12px;margin-right:14px}
  .sensorstest-icon-phone{width:18px;height:30px}
  .sensorstest-icon-ring-1{width:28px;height:28px}
  .sensorstest-icon-ring-2{width:38px;height:38px}
  .sensorstest-icon-ring-3{width:46px;height:46px}
  .sensorstest-text h3{font-size:16px}
  .sensorstest-text p.sensorstest-desc{font-size:13px}
  .sensorstest-features span{display:block;margin-right:0;margin-bottom:2px}
}

/* ============== Test multitouch (screen test) ============== */
.scrtest-app{margin:10px 0 18px}
.scrtest-instructions{background:#f0f9ff;border-left:4px solid #38bdf8;padding:10px 14px;border-radius:6px;font-size:14px;line-height:1.5;color:#0c4a6e;margin:10px 0 14px}
.scrtest-hud{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;background:#0f172a;color:#e2e8f0;border-radius:10px 10px 0 0;padding:12px 16px;border-bottom:1px solid #1e293b}
.scrtest-hud-stats{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.scrtest-stat{display:inline-flex;flex-direction:column;line-height:1.1}
.scrtest-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:rgba(226,232,240,.55);font-weight:600}
.scrtest-stat-value{font-family:'Menlo','Consolas',monospace;font-size:22px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}
.scrtest-stat-extra{font-size:11px;color:rgba(226,232,240,.55);font-family:'Menlo','Consolas',monospace;margin-top:1px}
.scrtest-stat-cov .scrtest-stat-value{color:#4ade80}
.scrtest-hud-actions{display:flex;gap:8px;flex-wrap:wrap}
.scrtest-btn-action{font-size:13px;padding:8px 14px;min-height:38px}
.scrtest-stage{position:relative;width:100%;height:70vh;min-height:420px;max-height:900px;background:#fafafa;border:2px solid #cbd5e1;border-top:0;border-radius:0 0 10px 10px;overflow:hidden;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;background-image:linear-gradient(rgba(148,163,184,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.12) 1px,transparent 1px);background-size:32px 32px;cursor:crosshair}
.scrtest-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;display:block}
.scrtest-touches{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.scrtest-touch{position:absolute;top:0;left:0;width:70px;height:70px;border-radius:50%;border:3px solid #ef4444;background:rgba(239,68,68,.28);color:#fff;font-weight:700;font-size:22px;display:flex;align-items:center;justify-content:center;text-shadow:0 1px 3px rgba(0,0,0,.65),0 0 6px rgba(0,0,0,.45);will-change:transform;transition:width .12s ease,height .12s ease;font-family:'Menlo','Consolas',monospace}
.scrtest-touch-noanim{transition:none}
.scrtest-stage-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);margin:0;font-size:18px;font-weight:600;color:#94a3b8;text-align:center;pointer-events:none;padding:12px 20px;border-radius:10px;background:rgba(255,255,255,.6);max-width:80%;transition:opacity .25s ease}
.scrtest-stage-hint-hidden{opacity:0}
.scrtest-btn-exit{position:absolute;top:14px;left:14px;display:none;background:rgba(15,23,42,.85);color:#fff;border:0;padding:8px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;z-index:5}
.scrtest-btn-exit:hover{background:rgba(15,23,42,.95)}
.scrtest-stage-hud{position:absolute;top:14px;right:14px;display:none;gap:14px;background:rgba(15,23,42,.85);color:#fff;border-radius:6px;padding:8px 12px;font-size:13px;z-index:5}
.scrtest-stage-hud-item{display:inline-flex;flex-direction:column;line-height:1.1}
.scrtest-stage-hud-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:rgba(255,255,255,.55);font-weight:600}
.scrtest-stage-hud-item span:last-child{font-family:'Menlo','Consolas',monospace;font-weight:700;font-size:16px}
.scrtest-toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);background:#0f172a;color:#fff;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:500;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:9999;box-shadow:0 6px 20px rgba(0,0,0,.25);max-width:90%;text-align:center}
.scrtest-toast-show{opacity:1;transform:translateX(-50%) translateY(0)}
.scrtest-declared-text{margin:8px 2px 0;color:#475569;font-size:13px;font-style:italic}
.scrtest-privacy{margin-top:14px;font-size:13px;color:#475569}
.scrtest-stage:fullscreen,.scrtest-stage:-webkit-full-screen,.scrtest-stage:-ms-fullscreen{width:100vw !important;height:100vh !important;max-height:none;min-height:0;border:0;border-radius:0;background:#fff;background-image:linear-gradient(rgba(148,163,184,.10) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.10) 1px,transparent 1px)}
.scrtest-stage-fs .scrtest-btn-exit,.scrtest-stage-fs .scrtest-stage-hud{display:flex}
.scrtest-stage-fs .scrtest-stage-hint{font-size:16px}
@media(max-width:767px){
  .scrtest-hud{padding:10px 12px;gap:8px}
  .scrtest-hud-stats{gap:14px;width:100%;justify-content:space-between}
  .scrtest-stat-value{font-size:18px}
  .scrtest-hud-actions{width:100%}
  .scrtest-btn-action{flex:1 1 auto}
  .scrtest-stage{height:65vh;min-height:380px}
  .scrtest-touch{width:62px;height:62px;font-size:18px;border-width:2.5px}
  .scrtest-stage-hint{font-size:15px}
  .scrtest-stage-hud{font-size:11px;gap:10px;padding:6px 10px}
  .scrtest-stage-hud-item span:last-child{font-size:14px}
}
@media(prefers-reduced-motion: reduce){
  .scrtest-touch{transition:none}
  .scrtest-stage-hint{transition:none}
  .scrtest-toast{transition:opacity .01s ease}
}

/* ============== Test de cámaras ============== */
.camtest-app{margin:14px 0 22px}
.camtest-privacy{background:#f0fdf4;border-left:4px solid #16a34a;padding:10px 14px;border-radius:6px;font-size:14px;line-height:1.5;color:#14532d;margin:14px 0 10px}
.camtest-howto{background:#f0f9ff;border-left:4px solid #38bdf8;padding:10px 14px;border-radius:6px;font-size:14px;line-height:1.5;color:#0c4a6e;margin:0 0 18px}
.camtest-start{text-align:center;padding:30px 12px;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:10px;margin-bottom:18px}
.camtest-btn-start{font-size:18px;padding:14px 30px;font-weight:700}
.camtest-controls{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;margin-bottom:14px}
.camtest-label{display:block;font-weight:700;color:#0f172a;font-size:13px;margin-bottom:5px;letter-spacing:.2px}
.camtest-select{font-size:14px}
.camtest-zoom-row{margin-top:12px}
.camtest-zoom-slider{width:100%;cursor:pointer}
.camtest-zoom-value{font-family:'Menlo','Consolas',monospace;font-weight:700;color:#0891b2;margin-left:8px}
.camtest-stage-row{margin:0 -15px}
.camtest-video-wrap{position:relative;background:#0f172a;border:2px solid #1e293b;border-radius:10px;overflow:hidden;aspect-ratio:16/9;max-width:720px;margin:0 auto;transition:border-color .25s ease,box-shadow .25s ease}
.camtest-video-wrap.camtest-recording{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.25);animation:camtest-rec-pulse 1.4s ease-in-out infinite}
@keyframes camtest-rec-pulse{0%,100%{box-shadow:0 0 0 3px rgba(220,38,38,.25)}50%{box-shadow:0 0 0 6px rgba(220,38,38,.15)}}
.camtest-video{width:100%;height:100%;display:block;object-fit:contain;background:#0f172a}
.camtest-rec-indicator{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;background:rgba(15,23,42,.85);color:#fff;padding:5px 10px;border-radius:6px;font-size:13px;font-weight:700;letter-spacing:.4px}
.camtest-rec-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#dc2626;animation:camtest-rec-dot 1s ease-in-out infinite}
@keyframes camtest-rec-dot{0%,100%{opacity:1}50%{opacity:.35}}
.camtest-rec-time{font-family:'Menlo','Consolas',monospace;font-weight:700}
.camtest-countdown{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:96px;font-weight:800;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.6);pointer-events:none;font-family:'Menlo','Consolas',monospace;line-height:1}
.camtest-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;justify-content:center}
.camtest-btn{font-size:14px;padding:9px 16px;min-height:40px}
.camtest-toast{margin-top:10px;background:#fef3c7;border-left:4px solid #f59e0b;color:#78350f;padding:10px 14px;border-radius:6px;font-size:14px;line-height:1.45;display:none}
.camtest-toast.camtest-toast-on{display:block}
.camtest-error{background:#fef2f2;border-left:4px solid #dc2626;color:#7f1d1d;padding:12px 16px;border-radius:6px;font-size:14px;margin:14px 0;line-height:1.5}
.camtest-hud{background:#0f172a;color:#e2e8f0;border-radius:10px;padding:14px 16px;margin-top:0;height:100%}
.camtest-hud-title{margin:0 0 12px;font-size:14px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #1e293b;padding-bottom:8px}
.camtest-hud-list{margin:0;font-size:13px}
.camtest-hud-list dt{font-weight:700;color:rgba(226,232,240,.6);font-size:11px;text-transform:uppercase;letter-spacing:.4px;margin-top:8px}
.camtest-hud-list dt:first-child{margin-top:0}
.camtest-hud-list dd{margin:2px 0 0;font-family:'Menlo','Consolas',monospace;color:#fff;word-break:break-word;font-size:13px;line-height:1.4}
.camtest-status-ok{color:#4ade80}
.camtest-status-loading{color:#fbbf24}
.camtest-status-warn{color:#f97316}
.camtest-status-err{color:#f87171}
.camtest-status-idle{color:#94a3b8}
.camtest-fps-warn{color:#fb923c !important}
.camtest-video-result{margin-top:18px;padding:14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px}
.camtest-video-playback{display:block;width:100%;max-width:720px;margin:8px 0 10px;background:#0f172a;border-radius:6px}
.camtest-video-actions{display:flex;flex-wrap:wrap;gap:8px}
.camtest-gallery-section{margin-top:20px;padding:14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px}
.camtest-gallery-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:10px}
.camtest-gallery-head .util-section-h{margin:0}
.camtest-gallery-empty{margin:0;color:#64748b;font-style:italic;font-size:14px}
.camtest-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.camtest-photo{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px;text-align:center}
.camtest-photo-img{width:100%;height:auto;border-radius:6px;display:block;background:#0f172a}
.camtest-photo-meta{margin:6px 0;font-size:12px;color:#475569;font-family:'Menlo','Consolas',monospace}
.camtest-photo-dl{display:block;font-size:12px}
@media(max-width:991px){
  .camtest-hud{margin-top:14px}
}
@media(max-width:767px){
  .camtest-stage-row{margin:0}
  .camtest-actions{flex-direction:column}
  .camtest-btn{width:100%}
  .camtest-countdown{font-size:72px}
  .camtest-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
  .camtest-btn-start{font-size:16px;padding:12px 24px}
}
@media(prefers-reduced-motion: reduce){
  .camtest-video-wrap{transition:none;animation:none !important}
  .camtest-video-wrap.camtest-recording{animation:none !important}
  .camtest-rec-dot{animation:none}
}
