.glowstat{display:grid;align-items:center;color:var(--text-primary)}.glowstat-stack{grid-template-rows:auto auto;justify-items:center;text-align:center;gap:var(--space-3)}.glowstat-row{grid-template-columns:auto 1fr;gap:var(--space-4);padding:var(--space-4) var(--space-4);background:var(--n02);border-radius:var(--radius-md)}.glowstat-badge{width:72px;height:72px;border-radius:50%;background:var(--n01, var(--n01));display:inline-flex;align-items:center;justify-content:center;position:relative;box-shadow:inset 0 0 0 1.5px color-mix(in oklab,var(--gs-tint) 55%,transparent),0 0 24px color-mix(in oklab,var(--gs-tint) 18%,transparent);flex-shrink:0}.glowstat-badge img{width:56px;height:56px;object-fit:contain;display:block}.glowstat-sm .glowstat-badge{width:56px;height:56px}.glowstat-sm .glowstat-badge img{width:42px;height:42px}.glowstat-lg .glowstat-badge{width:88px;height:88px}.glowstat-lg .glowstat-badge img{width:68px;height:68px}.glowstat-body{display:flex;flex-direction:column;gap:var(--space-1)}.glowstat-stack .glowstat-body{align-items:center}.glowstat-value{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:var(--fs-h3);line-height:1.1;letter-spacing:-.01em;color:var(--text-primary)}.glowstat-sm .glowstat-value{font-size:var(--fs-h3)}.glowstat-lg .glowstat-value{font-size:var(--fs-h2)}.glowstat-label{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--text-muted);line-height:1.3}.portal-componentes .mb-space-4{margin-bottom:var(--space-4)}.portal-componentes .mt-space-4{margin-top:var(--space-4)}.portal-componentes .comp-eyebrow-sub{font-family:var(--font-body);font-weight:var(--fw-medium);font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin:0 0 var(--space-3);line-height:1.2}.portal-componentes .comp-eyebrow-sub--top{margin-top:var(--space-5)}.portal-componentes .cs-title .accent{color:var(--text-primary)}.portal-componentes .cs-title .accent.is-firma{color:var(--g-brand)}.portal-componentes #buttons,.portal-componentes #composicion,.portal-componentes #stat-badges{scroll-margin-top:var(--space-5)}.portal-componentes .btn-collapse{background:var(--n02);border-radius:var(--radius-lg);padding:0;overflow:hidden;transition:background .16s ease}.portal-componentes .btn-collapse[open]{background:var(--n01)}.portal-componentes .btn-collapse>.surf-matrix-scroll{padding:0 var(--space-4) var(--space-4)}.portal-componentes .btn-collapse-summary{list-style:none;cursor:pointer;padding:var(--space-4) var(--space-4);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);user-select:none}.portal-componentes .btn-collapse-summary::-webkit-details-marker{display:none}.portal-componentes .btn-collapse-summary:after{content:"";width:10px;height:10px;border-right:1.6px solid var(--text-muted);border-bottom:1.6px solid var(--text-muted);transform:rotate(45deg) translate(-2px,-2px);transition:transform .2s ease;flex-shrink:0}.portal-componentes .btn-collapse[open] .btn-collapse-summary:after{transform:rotate(-135deg) translate(-2px,-2px)}.portal-componentes .btn-collapse-summary>.btn-heading{margin:0}.portal-componentes .btn-collapse-hint{font-family:var(--font-body);font-size:var(--fs-xs);color:var(--text-muted);margin-left:auto;margin-right:var(--space-1)}.portal-componentes .btn-collapse[open] .btn-collapse-hint:after{content:" · activa"}.portal-componentes .gs-anatomy{display:grid;grid-template-columns:220px 1fr;gap:var(--space-6);align-items:center;background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6)}.portal-componentes .gs-anatomy-stage{display:flex;justify-content:center}.portal-componentes .gs-anatomy-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.portal-componentes .gs-anatomy-list li{display:flex;gap:var(--space-3);align-items:flex-start;font-family:var(--font-body);font-size:var(--fs-body);line-height:1.5;color:var(--text-secondary)}.portal-componentes .gs-anatomy-list .gs-num{flex-shrink:0}.portal-componentes .gs-anatomy-text{flex:1;min-width:0}.portal-componentes .gs-anatomy-list strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.portal-componentes .gs-num{width:24px;height:24px;border-radius:50%;background:var(--tint-brand-14);color:var(--g-brand);font-family:var(--font-body);font-size:var(--fs-xs);font-weight:var(--fw-bold);display:inline-flex;align-items:center;justify-content:center;margin-top:var(--space-1)}@media(max-width:768px){.portal-componentes .gs-anatomy{grid-template-columns:1fr;gap:var(--space-4)}}.portal-componentes .gs-layouts{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:980px){.portal-componentes .gs-layouts{grid-template-columns:1fr}}.portal-componentes .gs-demo{gap:var(--space-4)}.portal-componentes .gs-demo-tag{align-self:flex-start;font-family:var(--font-mono);font-size:var(--fs-xs);font-weight:var(--fw-regular);letter-spacing:normal;text-transform:none;color:var(--g-brand);padding:var(--space-1) var(--space-2);background:var(--tint-brand-10);border-radius:var(--radius-pill)}.portal-componentes .gs-demo-when{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-secondary);margin:0}.portal-componentes .gs-stack-stage{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);padding:var(--space-5) var(--space-3);background:var(--n01);border-radius:var(--radius-lg)}.portal-componentes .gs-row-stage{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--n01);border-radius:var(--radius-lg)}.portal-componentes .gs-row-stage .glowstat-row{background:var(--n02)}.portal-componentes .gs-tint-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-2)}.portal-componentes .gs-tint-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:var(--space-3);background:var(--n02);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4)}.portal-componentes .gs-tint-sw{width:24px;height:24px;border-radius:50%;background:var(--gs-tint);box-shadow:inset 0 0 0 1.5px color-mix(in oklab,var(--gs-tint) 55%,transparent),0 0 16px color-mix(in oklab,var(--gs-tint) 35%,transparent)}.portal-componentes .gs-tint-hex{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-muted)}.ic-code-block{background:var(--n00);border-radius:var(--radius-sm);padding:var(--space-5) var(--space-5);overflow-x:auto}.ic-code-block pre{margin:0}.ic-code-block code{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:var(--fs-body-sm);color:var(--text-secondary);line-height:1.8}.portal-componentes .surf-toc{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);margin:0 0 var(--space-6);padding:var(--space-4) var(--space-4);background:var(--n01);border-radius:var(--radius-lg)}.portal-componentes .surf-toc-label{font-family:var(--font-body);font-weight:var(--fw-semibold);font-size:var(--fs-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);padding:0 var(--space-2) 0 var(--space-1)}.portal-componentes .surf-toc-chip{display:inline-flex;align-items:center;gap:var(--space-2);height:28px;padding:0 var(--space-3) 0 var(--space-1);border-radius:var(--radius-pill);font-family:var(--font-body);font-weight:var(--fw-medium);font-size:var(--fs-xs);color:var(--text-secondary);background:var(--tint-white-05);text-decoration:none;transition:background .16s ease,color .16s ease}.portal-componentes .surf-toc-chip:hover{background:var(--tint-brand-10);color:var(--g-brand)}.portal-componentes .surf-toc-chip.is-active{background:var(--tint-brand-14);color:var(--white)}.portal-componentes .surf-toc-letter{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-pill);font-family:var(--font-mono);font-weight:var(--fw-semibold);font-size:var(--fs-xs);letter-spacing:0;color:var(--g-brand);background:var(--tint-brand-10);flex-shrink:0}.portal-componentes .surf-toc-chip.is-active .surf-toc-letter{color:var(--n00);background:var(--g-brand)}@media(max-width:600px){.portal-componentes .surf-toc{gap:var(--space-1);padding:var(--space-3)}.portal-componentes .surf-toc-chip{font-size:var(--fs-xs);height:26px;padding:0 var(--space-2) 0 var(--space-1)}}.portal-componentes .surf-matrix-scroll{overflow-x:auto}.portal-componentes .surf-matrix{width:100%;border-collapse:collapse}.portal-componentes .surf-matrix th{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:var(--space-2) var(--space-4);text-align:center;border-bottom:1px solid var(--tint-white-06)}.portal-componentes .sm-corner{border-bottom:1px solid var(--tint-white-06)}.portal-componentes .surf-matrix td{padding:var(--space-3) var(--space-4);text-align:center;border-bottom:1px solid var(--tint-white-03)}.portal-componentes .surf-matrix tr:last-child td{border-bottom:none}.portal-componentes .sm-row-label{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-tertiary);text-align:left!important;white-space:nowrap;padding-right:var(--space-5)}.portal-componentes .snc-chip-well{background:var(--n03);color:var(--text-secondary);border:1px solid rgba(255,255,255,.12)}.portal-componentes .cmp-stage{background:var(--n00);padding:var(--space-4);border-radius:var(--radius-2xl);display:flex;flex-direction:column;gap:var(--space-4)}.portal-componentes .cmp-hero{background:linear-gradient(155deg,var(--n02) 36.755%,var(--n01) 123.54%);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-5);display:grid;grid-template-columns:1fr auto;gap:var(--space-5);align-items:center;min-height:160px}.portal-componentes .cmp-hero-text{display:flex;flex-direction:column;gap:var(--space-2)}.portal-componentes .cmp-eyebrow{font-family:var(--font-body);font-weight:var(--fw-semibold);font-size:var(--fs-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted)}.portal-componentes .cmp-hero-title{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-h3);color:var(--white);margin:0;letter-spacing:-.02em;line-height:1.2}.portal-componentes .cmp-hero-lead{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.55;color:var(--text-tertiary);margin:0;max-width:380px}.portal-componentes .cmp-hero-art{display:flex;flex-direction:column;gap:var(--space-2);min-width:180px}.portal-componentes .cmp-hero-diagram{display:flex;align-items:center;gap:var(--space-2)}.portal-componentes .cmp-node{width:28px;height:28px;border-radius:50%;background:var(--n03);display:flex;align-items:center;justify-content:center;flex-shrink:0}.portal-componentes .cmp-line{flex:1;height:1px;background:#ffffff1a}.portal-componentes .cmp-pill{font-family:var(--font-body);font-weight:var(--fw-regular);font-size:var(--fs-xs);letter-spacing:normal;text-transform:none;color:var(--text-secondary);background:var(--n03);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill)}.portal-componentes .cmp-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.portal-componentes .cmp-card{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.portal-componentes .cmp-card-title{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-body);color:var(--white);margin:0;letter-spacing:-.01em}.portal-componentes .cmp-card-desc{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-tertiary);margin:0}.portal-componentes .cmp-input{background:var(--tint-white-03);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);margin-top:var(--space-1)}.portal-componentes .cmp-input-placeholder{font-family:var(--font-body);font-size:var(--fs-xs);color:var(--text-muted)}.portal-componentes .cmp-codewell{background:var(--n03);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);margin-top:var(--space-1);font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--g-brand)}.portal-componentes .cmp-link{font-family:var(--font-body);font-weight:var(--fw-semibold);font-size:var(--fs-xs);color:var(--g-brand);margin-top:var(--space-1)}.portal-componentes .cmp-tag{font-family:var(--font-mono);font-weight:var(--fw-semibold);font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);align-self:flex-start;background:var(--tint-white-08);padding:var(--space-1) var(--space-2);border-radius:var(--radius-xs);margin-top:var(--space-1)}.portal-componentes .cmp-tag-accent{color:var(--g-brand);background:var(--tint-brand-14)}.portal-componentes .cmp-mini-tinted-success .cmp-tag{color:var(--success-light);background:#22c55e2e}.portal-componentes .cmp-row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.portal-componentes .cmp-mini{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1);min-height:130px}.portal-componentes .cmp-mini-title{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-body-sm);color:var(--white);margin-top:var(--space-1);letter-spacing:-.01em}.portal-componentes .cmp-mini-meta{font-family:var(--font-body);font-size:var(--fs-xs);color:var(--text-tertiary)}.portal-componentes .cmp-mini-mystery{background:linear-gradient(135deg,var(--tint-brand-06) 0%,transparent 55%),#0a0d0acc;box-shadow:inset 0 0 0 .7px #ffffff2e,inset 0 1px 0 var(--tint-brand-30),inset 0 1px 2px #ffffff1a,inset 0 24px 70px 0 var(--tint-brand-14),inset 0 50px 100px #a5ef0a38;position:relative;overflow:hidden;container-type:inline-size;isolation:isolate}.portal-componentes .cmp-mini-mystery:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;filter:blur(10.6cqi);background:radial-gradient(ellipse 33.1% 10.1% at 50.1% 99%,rgba(179,241,49,.6) 0%,transparent 100%),radial-gradient(ellipse 41.2% 7.1% at 50.1% 7.7%,rgba(116,124,138,.6) 0%,transparent 100%)}.portal-componentes .cmp-mini-mystery>*{position:relative;z-index:1}.portal-componentes .cmp-mini-mystery-glyph{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-h3);color:var(--white);line-height:1;text-shadow:0 0 8px rgba(179,241,49,.65),0 0 16px var(--tint-brand-30)}.portal-componentes .cmp-mini-tinted-success{background-image:linear-gradient(0deg,rgba(34,197,94,.22) 0%,rgba(34,197,94,.12) 30%,rgba(34,197,94,.04) 60%,transparent 95%);background-color:var(--n01)}.portal-componentes #composicion .note-callout{margin-top:var(--space-4)}@media(max-width:860px){.portal-componentes .cmp-hero,.portal-componentes .cmp-row-2{grid-template-columns:1fr}.portal-componentes .cmp-row-4{grid-template-columns:1fr 1fr}}@media(max-width:600px){.portal-componentes .cmp-row-4{grid-template-columns:1fr}}.portal-componentes .btn-section{margin-bottom:var(--space-6)}.portal-componentes .btn-section:last-child{margin-bottom:0}.portal-componentes .btn-heading{font-family:var(--font-body);font-weight:var(--fw-semibold);font-size:var(--fs-body-sm);letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);margin:0 0 var(--space-4);line-height:1.2}.portal-componentes .yesno-col{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5)}.portal-componentes .yesno-col-label{font-family:var(--font-body);font-weight:var(--fw-bold);font-size:var(--fs-xs);letter-spacing:.18em;text-transform:uppercase;margin-bottom:var(--space-3);display:block}.portal-componentes .yesno-col-yes .yesno-col-label{color:var(--g-brand)}.portal-componentes .yesno-col-no .yesno-col-label{color:var(--error-vivid)}.portal-componentes .yesno-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.portal-componentes .yesno-list li{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-tertiary);padding-left:var(--space-4);position:relative}.portal-componentes .yesno-list li:before{content:"";position:absolute;left:0;top:.32em;width:12px;height:12px;background-repeat:no-repeat;background-position:center;background-size:12px 12px}.portal-componentes .yesno-col-yes .yesno-list li:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' width='12' height='12' fill='none' stroke='%23B3F131' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 8.5 6.5 12 13 4.5'/%3E%3C/svg%3E")}.portal-componentes .yesno-col-no .yesno-list li:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' width='12' height='12' fill='none' stroke='%23FB7E7E' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M4 4l8 8M12 4l-8 8'/%3E%3C/svg%3E")}.portal-componentes .yesno-list strong{color:var(--text-secondary);font-weight:var(--fw-semibold)}.portal-componentes .btn-primary.btn-hover-demo{background:var(--g-bright);box-shadow:0 0 24px var(--tint-brand-30)}.portal-componentes .btn-primary.btn-active-demo{background:#a5ef0a;transform:scale(.98)}.portal-componentes .btn-primary.btn-focus-demo{box-shadow:0 0 36px 4px #b3f1318c}.portal-componentes .btn-tertiary.btn-hover-demo{background:var(--n03)}.portal-componentes .btn-tertiary.btn-active-demo{background:var(--n03);transform:scale(.98)}.portal-componentes .btn-tertiary.btn-focus-demo{box-shadow:0 0 28px 3px #b3f13166}.portal-componentes .btn-grid-sizes{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.portal-componentes .btn-grid-states{margin-top:var(--space-1)}.portal-componentes .btn-state-row{display:flex;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-5);background:var(--n02);border-radius:var(--radius-lg);margin-bottom:var(--space-3)}.portal-componentes .btn-state-note{font-family:var(--font-body);font-size:var(--fs-xs);line-height:1.55;color:var(--text-tertiary);margin:0}.portal-componentes .btn-state-note code{font-family:var(--font-mono);font-size:var(--fs-body-sm);background:var(--tint-white-05);padding:var(--space-1) var(--space-1);border-radius:var(--radius-xs);color:var(--text-secondary)}.portal-componentes .btn-state-note strong{color:var(--text-secondary);font-weight:var(--fw-semibold)}.portal-componentes .btn-demo{align-items:flex-start}.portal-componentes .btn-tag{font-family:var(--font-mono);font-weight:var(--fw-regular);font-size:var(--fs-xs);letter-spacing:normal;text-transform:none;color:var(--text-muted);background:var(--tint-white-05);padding:var(--space-1) var(--space-2);border-radius:var(--radius-xs);margin-top:var(--space-1)}.portal-componentes .btn-when{font-family:var(--font-body);font-size:var(--fs-xs);line-height:1.5;color:var(--text-tertiary);margin:0}.portal-componentes .btn-anatomy-col{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.portal-componentes .btn-anatomy-demo{display:flex;align-items:center;justify-content:center;min-height:70px;background:var(--n00);border-radius:var(--radius-sm)}.portal-componentes .btn-anatomy-label{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-body);color:var(--white);letter-spacing:-.01em}.portal-componentes .btn-anatomy-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:var(--space-1)}.portal-componentes .btn-anatomy-list li{font-family:var(--font-body);font-size:var(--fs-xs);line-height:1.5;color:var(--text-tertiary);padding-left:var(--space-3);position:relative}.portal-componentes .btn-anatomy-list li:before{content:"·";position:absolute;left:0;color:var(--g-brand);font-weight:var(--fw-bold)}.portal-componentes .chips-semantic-demo{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-wrap:wrap;gap:var(--space-2)}.portal-componentes .btn-specs th,.portal-componentes .btn-specs td{text-align:left;padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--fs-xs);line-height:1.4;color:var(--text-tertiary)}.portal-componentes .btn-specs th{font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;font-weight:var(--fw-regular);color:var(--neutral-05)}.portal-componentes .btn-specs .sm-row-label{color:var(--text-secondary);font-weight:var(--fw-medium)}@media(max-width:768px){.portal-componentes .btn-grid-sizes{grid-template-columns:1fr}}.portal-componentes .code-tag-accent{background:var(--tint-brand-10);color:var(--g-brand)}.portal-componentes .ctag-demo-grid{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.portal-componentes .ctag-demo-row{display:flex;align-items:center;gap:var(--space-4)}.portal-componentes .ctag-label{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--text-tertiary)}.portal-componentes .ctag-cases{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.portal-componentes .ctag-case-line{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.55;color:var(--text-tertiary);margin:0}.portal-componentes .ico-hierarchy{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin:var(--space-1) 0 var(--space-6)}.portal-componentes .ico-tier{background:var(--n02);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.portal-componentes .ico-tier-preview{width:100%;height:80px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--n01)}.portal-componentes .ico-tier-preview-flat svg{color:var(--text-primary)}.portal-componentes .ico-tier-preview-glow img{width:56px;height:56px}.portal-componentes .ico-tier-preview-3d img{width:72px;height:72px}.portal-componentes .ico-tier-body{display:flex;flex-direction:column;gap:var(--space-1)}.portal-componentes .ico-tier-name{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-body-lg);color:var(--white);margin:0;letter-spacing:-.02em;line-height:1.1}.portal-componentes .ico-tier-when{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-tertiary);margin:0}@media(max-width:860px){.portal-componentes .ico-hierarchy{grid-template-columns:1fr}}.portal-componentes .ico-examples{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin:0 0 var(--space-6)}.portal-componentes .ico-example{display:flex;flex-direction:column;gap:var(--space-3);align-items:center}.portal-componentes .ico-example-stage{width:100%;height:96px;border-radius:var(--radius-lg);background:var(--n01);display:flex;align-items:center;justify-content:center}.portal-componentes .ico-example-cap{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--text-tertiary);text-align:center;line-height:1.4}@media(max-width:600px){.portal-componentes .ico-examples{grid-template-columns:1fr}}.portal-componentes .ico-catalog-cta{margin-top:var(--space-2)}.portal-componentes .flat-color-rule{margin:0 0 var(--space-6);padding:var(--space-5);background:var(--n02);border-radius:var(--radius-2xl)}.portal-componentes .flat-color-rule-head{margin-bottom:var(--space-4);max-width:720px}.portal-componentes .flat-color-rule-title{font-family:var(--font-display);font-size:var(--fs-body-lg);font-weight:var(--fw-bold);color:var(--text-primary);margin:0 0 var(--space-1);letter-spacing:-.01em}.portal-componentes .flat-color-rule-sub{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.55;color:var(--text-secondary);margin:0}.portal-componentes .flat-color-rule-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-2)}.portal-componentes .flat-color-swatch{background:var(--n01);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);transition:transform .16s ease}.portal-componentes .flat-color-swatch:hover{transform:translateY(-2px)}.portal-componentes .flat-color-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--n00);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.portal-componentes .flat-color-name{font-family:var(--font-display);font-size:var(--fs-body-sm);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:-.01em}.portal-componentes .flat-color-hex{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-secondary);letter-spacing:.02em}.portal-componentes .flat-color-use{font-family:var(--font-body);font-size:var(--fs-xs);color:var(--text-muted);line-height:1.4;margin-top:var(--space-1)}@media(max-width:768px){.portal-componentes .flat-color-rule{padding:var(--space-4)}.portal-componentes .flat-color-rule-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.portal-componentes #buttons,.portal-componentes #chips,.portal-componentes #codetags,.portal-componentes #notes,.portal-componentes #iconos,.portal-componentes #composicion,.portal-componentes #cards{scroll-margin-top:var(--space-6)}.portal-componentes .cardsys-title{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-body);color:var(--text-primary);margin:0;letter-spacing:-.01em}.portal-componentes .cardsys-desc{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.55;color:var(--text-tertiary);margin:0}.portal-componentes .cardsys-iconrow{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-2)}.portal-componentes .frm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}.portal-componentes .frm-field{display:flex;flex-direction:column;gap:var(--space-2)}.portal-componentes .frm-label{font-family:var(--font-body);font-size:var(--fs-body-sm);font-weight:var(--fw-medium);color:var(--text-secondary)}.portal-componentes .frm-label-off{color:var(--text-muted)}.portal-componentes .frm-input{display:flex;align-items:center;gap:var(--space-2);min-height:44px;padding:0 var(--space-4);background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.portal-componentes .frm-textarea{min-height:80px;align-items:flex-start;padding:var(--space-3) var(--space-4)}.portal-componentes .frm-ph{font-family:var(--font-body);font-size:var(--fs-body);color:var(--text-muted)}.portal-componentes .frm-val{font-family:var(--font-body);font-size:var(--fs-body);color:var(--text-primary)}.portal-componentes .frm-input.is-focus{border-color:#b3f13173;box-shadow:0 0 22px 1px #b3f13138}.portal-componentes .frm-caret{width:1.5px;height:18px;background:var(--g-brand);animation:frmCaret 1.05s steps(1) infinite}@keyframes frmCaret{50%{opacity:0}}.portal-componentes .frm-input.is-error{border-color:#fb7e7e8c}.portal-componentes .frm-input.is-disabled{background:var(--tint-white-03);border-style:dashed}.portal-componentes .frm-input.is-disabled .frm-ph{color:var(--text-muted);opacity:.6}.portal-componentes .frm-help{font-family:var(--font-body);font-size:var(--fs-xs);color:var(--text-muted)}.portal-componentes .frm-help.is-error-text{color:var(--e-500)}.portal-componentes .frm-select{cursor:default}.portal-componentes .frm-chev{width:16px;height:16px;margin-left:auto;color:var(--text-muted)}.portal-componentes .frm-check,.portal-componentes .frm-radio{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--text-secondary)}.portal-componentes .frm-box{width:18px;height:18px;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;color:var(--n00);flex-shrink:0}.portal-componentes .frm-box svg{width:12px;height:12px;opacity:0}.portal-componentes .frm-box.is-on{background:var(--g-brand);border-color:var(--g-brand)}.portal-componentes .frm-box.is-on svg{opacity:1}.portal-componentes .frm-dot{width:18px;height:18px;border:1px solid rgba(255,255,255,.18);border-radius:50%;flex-shrink:0;position:relative}.portal-componentes .frm-dot.is-on{border-color:var(--g-brand)}.portal-componentes .frm-dot.is-on:after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--g-brand)}.portal-componentes .est-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-4)}.portal-componentes .est-card{background:var(--n02);border-radius:var(--radius-2xl);overflow:hidden;display:flex;flex-direction:column}.portal-componentes .est-tag{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.16em;text-transform:uppercase;color:var(--g-brand);padding:var(--space-4) var(--space-4) 0}.portal-componentes .est-tag-no{color:var(--e-500)}.portal-componentes .est-tag-load{color:var(--text-muted)}.portal-componentes .est-stage{margin:var(--space-4) var(--space-4) 0;background:var(--n00);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-5);min-height:190px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-2)}.portal-componentes .est-illu{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--tint-brand-10);border-radius:50%;margin-bottom:var(--space-1)}.portal-componentes .est-illu-no{background:var(--tint-error-12)}.portal-componentes .est-title{font-family:var(--font-display);font-size:var(--fs-body-lg);font-weight:var(--fw-bold);color:var(--text-primary);margin:0;letter-spacing:-.01em}.portal-componentes .est-desc{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-secondary);margin:0;max-width:24ch}.portal-componentes .est-cta{margin-top:var(--space-2);font-family:var(--font-body);font-size:var(--fs-body-sm);font-weight:var(--fw-medium);color:var(--n00);background:var(--g-brand);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill)}.portal-componentes .est-cta-no{color:var(--text-primary);background:var(--tint-white-08)}.portal-componentes .est-note{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-muted);margin:0;padding:var(--space-4) var(--space-4) var(--space-4)}.portal-componentes .est-skel{height:14px;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--tint-white-05) 25%,rgba(255,255,255,.1) 37%,var(--tint-white-05) 63%);background-size:400% 100%;animation:estSkel 1.4s ease infinite}.portal-componentes .est-skel-1{width:80%}.portal-componentes .est-skel-2{width:100%}.portal-componentes .est-skel-3{width:60%;margin-bottom:var(--space-1)}@keyframes estSkel{0%{background-position:100% 0}to{background-position:0 0}}.portal-componentes .est-spinner{width:26px;height:26px;border-radius:50%;border:2.5px solid rgba(255,255,255,.1);border-top-color:var(--g-brand);margin-top:var(--space-2);animation:estSpin .8s linear infinite}@keyframes estSpin{to{transform:rotate(360deg)}}@media(max-width:860px){.portal-componentes .frm-grid,.portal-componentes .est-grid{grid-template-columns:1fr}}.portal-componentes .comp-tabsystem{margin-top:0}.portal-componentes .comp-tabnav{display:flex;width:fit-content;margin-bottom:0;overflow-x:auto;scrollbar-width:none;background:var(--n03);border-radius:var(--radius-pill);padding:2px;gap:4px}.portal-componentes .comp-tabnav::-webkit-scrollbar{display:none}.portal-componentes .comp-tab{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:var(--fs-body-sm);font-weight:var(--fw-medium);color:var(--text-muted);background:none;border:none;border-radius:var(--radius-pill);padding:7px 14px;cursor:pointer;white-space:nowrap;transition:color .14s ease,background .14s ease;letter-spacing:0}.portal-componentes .comp-tab svg{flex-shrink:0}.portal-componentes .comp-tab:hover{color:var(--text-secondary);background:var(--tint-white-06)}.portal-componentes .comp-tab[aria-selected=true]{color:var(--text-primary);font-weight:var(--fw-semibold);background:var(--n02)}.portal-componentes .comp-panel{padding-top:var(--space-7)}.portal-componentes .comp-panel[hidden]{display:none}.portal-componentes .toast-variants{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-3)}.portal-componentes .toast-variant-featured{background:color-mix(in oklab,var(--n02) 92%,var(--g-brand) 8%);box-shadow:inset 0 0 0 1px #b3f13129}.portal-componentes .toast-variant-featured:hover{background:color-mix(in oklab,var(--n02) 88%,var(--g-brand) 12%)}.portal-componentes .toast-variant-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);background:var(--tint-white-05);margin-bottom:var(--space-1)}.portal-componentes .toast-variant[data-tone=info] .toast-variant-icon{color:#73c8e8;background:#73c8e81a}.portal-componentes .toast-variant[data-tone=success] .toast-variant-icon{color:var(--s-500);background:#22c55e1a}.portal-componentes .toast-variant[data-tone=warning] .toast-variant-icon{color:var(--w-500);background:#eccf071a}.portal-componentes .toast-variant[data-tone=error] .toast-variant-icon{color:var(--e-500);background:var(--tint-error-12)}.portal-componentes .toast-variant[data-tone=neutral] .toast-variant-icon{color:var(--text-secondary)}.portal-componentes .toast-variant[data-tone=achievement] .toast-variant-icon{color:var(--g-brand);background:var(--tint-brand-14)}.portal-componentes .toast-variant-name{font-family:var(--font-display);font-size:var(--fs-body);font-weight:var(--fw-semibold);color:var(--text-primary);margin:0;letter-spacing:-.01em}.portal-componentes .toast-variant-when{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--text-secondary);margin:0;flex:1}.portal-componentes .toast-variant-trigger{align-self:flex-start;margin-top:var(--space-2);font-family:var(--font-body);font-size:var(--fs-body-sm);font-weight:var(--fw-semibold);color:var(--text-primary);background:var(--tint-white-06);border:none;border-radius:var(--radius-pill);padding:var(--space-1) var(--space-4);cursor:pointer;transition:background .14s ease,color .14s ease}.portal-componentes .toast-variant-trigger:hover{background:#ffffff1f}.portal-componentes .toast-variant-featured .toast-variant-trigger{background:var(--g-brand);color:var(--n01)}.portal-componentes .toast-variant-featured .toast-variant-trigger:hover{background:var(--g-brand);box-shadow:0 0 20px #b3f13159}@media(max-width:980px){.portal-componentes .toast-variants{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:600px){.portal-componentes .toast-variants{grid-template-columns:1fr}}
