@import"https://fonts.googleapis.com/css2?family=Kalam:wght@700&family=Patrick+Hand&display=swap";:root{--root-bg: #fdfbf7;--panel-bg: #ffffff;--text-primary: #2d2d2d;--text-secondary: #2d2d2d;--border-color: #2d2d2d;--accent: #ff4d4d;--accent-hover: #cc3d3d;--blue-pen: #2d5da1;--muted-paper: #e5e0d8;--shadow-sm: 4px 4px 0px 0px #2d2d2d;--shadow-md: 4px 4px 0px 0px #2d2d2d;--shadow-lg: 8px 8px 0px 0px #2d2d2d;--shadow-pressed: 2px 2px 0px 0px #2d2d2d;--radius-wobbly: 255px 15px 225px 15px / 15px 225px 15px 255px;--radius-subtle: 2px 255px 3px 255px / 255px 5px 225px 3px;--radius-oval: 50% 50% 50% 50% / 60% 40% 60% 40%;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Patrick Hand,cursive;background:var(--root-bg);background-image:radial-gradient(#e5e0d8 1px,transparent 1px);background-size:24px 24px;color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:Kalam,cursive}button{font-family:inherit;cursor:pointer;border:none;background:transparent}a{color:inherit;text-decoration:none}.container{max-width:1440px;margin:0 auto;padding:0 2rem}.wobbly-box{background:var(--panel-bg);border:3px solid var(--border-color);border-radius:var(--radius-wobbly);box-shadow:var(--shadow-sm)}.color-swatch{flex:1;min-width:0;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:2rem 1rem;transition:flex .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.color-swatch:hover{flex:1.15}.swatch-actions{opacity:0;transform:translateY(10px);transition:all .2s ease;display:flex;gap:.5rem}.swatch-actions.top-actions{transform:translateY(-10px)}.color-swatch:hover .swatch-actions{opacity:1;transform:translateY(0)}.icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-oval);background:var(--panel-bg);border:3px solid var(--border-color);box-shadow:var(--shadow-sm);color:var(--text-primary);transition:all .2s}.icon-btn:hover{background:var(--muted-paper);transform:scale(1.05) rotate(5deg);box-shadow:var(--shadow-pressed)}.icon-btn:active{transform:scale(.95);box-shadow:none}.swatch-info{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.hex-code{font-size:clamp(1rem,2vw,1.75rem);font-weight:700;font-family:Kalam,cursive;letter-spacing:.05em;cursor:pointer;transition:transform .2s}.hex-code:hover{transform:scale(1.05) rotate(-2deg)}.color-formats{display:flex;flex-direction:column;font-size:clamp(.6rem,1vw,.8rem);opacity:.8;gap:.25rem}.copy-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--panel-bg);color:var(--text-primary);border:3px solid var(--border-color);box-shadow:var(--shadow-sm);padding:.5rem 1rem;border-radius:var(--radius-wobbly);font-size:1.1rem;font-weight:500;pointer-events:none;animation:fadeInOut 1.5s ease forwards;transform:rotate(2deg)}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-30%)}15%{opacity:1;transform:translate(-50%,-50%)}85%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-70%)}}.editor-popover{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:var(--panel-bg);border-radius:var(--radius-wobbly);padding:1.5rem;width:200px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:1rem;z-index:100;color:var(--text-primary);border:3px solid var(--border-color);cursor:default}.editor-popover:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:12px;height:12px;background:var(--panel-bg);border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.close-editor-btn{position:absolute;top:.5rem;right:.5rem;color:var(--text-secondary);background:none;padding:.25rem;border-radius:4px}.close-editor-btn:hover{background:#0000000d;color:var(--text-primary)}.editor-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.editor-row label{font-size:.9rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-family:Kalam,cursive}.editor-row input[type=text]{width:100%;padding:.5rem;border:3px solid var(--border-color);border-radius:var(--radius-wobbly);font-size:1.1rem;font-family:inherit;outline:none;transition:var(--transition)}.editor-row input[type=text]:focus{border-color:var(--blue-pen);box-shadow:0 0 0 2px #2d5da11a}.native-color-picker{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;width:100%;height:36px;border-radius:6px;cursor:pointer;padding:0;background:transparent}.native-color-picker::-webkit-color-swatch-wrapper{padding:0}.native-color-picker::-webkit-color-swatch{border:3px solid var(--border-color);border-radius:var(--radius-subtle)}.eyedropper-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem;border-radius:var(--radius-oval);background:var(--panel-bg);border:3px solid var(--border-color);box-shadow:var(--shadow-sm);color:var(--text-primary);font-size:1.1rem;font-weight:500;transition:var(--transition)}.eyedropper-btn:hover{background:var(--muted-paper);transform:translateY(2px);box-shadow:var(--shadow-pressed)}.generator-container{display:flex;flex-direction:column;height:100%}.generator-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.generator-header h2{font-size:2rem;font-weight:700;transform:rotate(-1deg)}.generator-actions{display:flex;align-items:center;gap:1.5rem}.hint{color:var(--text-secondary);font-size:.875rem}.primary-btn{display:flex;align-items:center;gap:.5rem;background-color:var(--accent);color:#fff;padding:.6rem 1.25rem;border:3px solid var(--border-color);border-radius:var(--radius-oval);font-weight:500;font-size:1.1rem;transition:var(--transition);box-shadow:var(--shadow-sm);transform:rotate(1deg)}.primary-btn:hover{background-color:var(--accent-hover);transform:translateY(2px) rotate(1deg);box-shadow:var(--shadow-pressed)}.primary-btn:active{transform:translateY(4px) rotate(1deg);box-shadow:none}.action-group{display:flex;align-items:center;gap:.5rem}.count-selector{display:flex;align-items:center;gap:.5rem;background:var(--panel-bg);border:3px solid var(--border-color);padding:.25rem .5rem .25rem 1rem;border-radius:var(--radius-wobbly);font-size:1.1rem;font-weight:500;box-shadow:var(--shadow-sm);transform:rotate(-1deg)}.count-selector input{width:45px;border:none;background:#0000000d;border-radius:var(--radius-wobbly);padding:.25rem;text-align:center;font-size:1.1rem;font-weight:600;outline:none;font-family:inherit}.harmony-select{padding:.55rem 1rem;border-radius:var(--radius-wobbly);border:3px solid var(--border-color);background:var(--panel-bg);color:var(--text-primary);font-family:inherit;font-size:1.1rem;font-weight:500;outline:none;cursor:pointer;box-shadow:var(--shadow-sm);transform:rotate(1deg)}.secondary-btn{display:flex;align-items:center;gap:.5rem;background-color:var(--panel-bg);border:3px solid var(--border-color);color:var(--text-primary);padding:.55rem 1rem;border-radius:var(--radius-oval);font-weight:500;font-size:1.1rem;transition:var(--transition);box-shadow:var(--shadow-sm)}.secondary-btn:hover,.secondary-btn.active{background-color:var(--muted-paper);transform:translateY(2px);box-shadow:var(--shadow-pressed)}.secondary-btn:disabled{opacity:.8;cursor:default}.text-success{color:#10b981}.export-wrapper{position:relative}.export-menu{position:absolute;top:110%;right:0;background:var(--panel-bg);border:3px solid var(--border-color);border-radius:var(--radius-wobbly);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;padding:.5rem;width:max-content;min-width:200px;z-index:100}.export-menu button{padding:.6rem 1rem;text-align:left;border-radius:var(--radius-subtle);font-size:1.1rem;transition:var(--transition);color:var(--text-primary);font-family:Patrick Hand,cursive;background:transparent;display:flex;align-items:center;gap:.75rem;white-space:nowrap}.export-menu button:hover{background:var(--muted-paper);transform:translate(4px)}@media(max-width:768px){.hide-mobile{display:none}}.palette-swatches{display:flex;flex:1;border-radius:var(--radius-wobbly);border:4px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-lg);min-height:500px;margin:10px}.extractor-container{max-width:800px;margin:0 auto;padding:2rem 0;display:flex;flex-direction:column;gap:2rem}.extractor-header{text-align:center}.extractor-header h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:700;transform:rotate(1deg)}.dropzone{border:3px dashed var(--border-color);border-radius:var(--radius-wobbly);background:var(--panel-bg);padding:4rem 2rem;text-align:center;position:relative;transition:var(--transition);min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--shadow-sm);transform:rotate(-1deg)}.dropzone.dragging{border-color:var(--accent);background:var(--muted-paper)}.dropzone.has-image{padding:0;border-style:solid;border-width:4px}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-secondary)}.upload-icon{color:var(--accent);margin-bottom:1rem}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.preview-container{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;background:#f1f5f9}.preview-container img{max-width:100%;max-height:400px;object-fit:contain}.change-img-btn{position:absolute;top:1rem;right:1rem;background:var(--panel-bg);color:var(--text-primary);border:3px solid var(--border-color);box-shadow:var(--shadow-sm);padding:.5rem 1rem;border-radius:var(--radius-wobbly);font-size:1.1rem;font-weight:500;cursor:pointer;font-family:inherit;transition:var(--transition)}.change-img-btn:hover{background:var(--muted-paper);transform:translateY(2px);box-shadow:var(--shadow-pressed)}.extracted-palette-section{background:var(--panel-bg);padding:2rem;border-radius:var(--radius-wobbly);box-shadow:var(--shadow-lg);border:4px solid var(--border-color);display:flex;flex-direction:column;align-items:center;gap:1.5rem;transform:rotate(1deg)}.extracted-swatches{display:flex;width:100%;height:100px;border-radius:var(--radius-wobbly);border:3px solid var(--border-color);box-shadow:var(--shadow-sm);overflow:hidden}.mini-swatch{flex:1;display:flex;align-items:center;justify-content:center;transition:flex .3s ease;font-weight:600;font-size:1.1rem;font-family:Kalam,cursive}.mini-swatch:hover{flex:1.5}.use-palette-btn{margin-top:1rem}.contrast-container{width:100%;padding:2rem 5%;display:flex;flex-direction:column;gap:2rem}.contrast-header{text-align:center}.contrast-header h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:700;transform:rotate(-1deg)}.checker-layout{display:grid;grid-template-columns:1fr 1.5fr 1.5fr;gap:2rem;align-items:stretch}.color-inputs{display:flex;flex-direction:column;gap:1.5rem;background:var(--panel-bg);padding:2rem;border-radius:var(--radius-wobbly);box-shadow:var(--shadow-sm);border:3px solid var(--border-color);transform:rotate(1deg)}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-weight:600;color:var(--text-secondary);font-size:1.1rem;font-family:Kalam,cursive}.color-input-wrapper{display:flex;align-items:center;gap:1rem}.native-color{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;width:50px;height:50px;border-radius:var(--radius-wobbly);cursor:pointer;padding:0;background:transparent}.native-color::-webkit-color-swatch-wrapper{padding:0}.native-color::-webkit-color-swatch{border:3px solid var(--border-color);border-radius:var(--radius-wobbly)}.text-input{flex:1;padding:.75rem 1rem;font-size:1.1rem;border:3px solid var(--border-color);border-radius:var(--radius-wobbly);outline:none;transition:var(--transition);font-family:inherit;box-shadow:var(--shadow-sm)}.text-input:focus{border-color:var(--blue-pen);box-shadow:0 0 0 2px #2d5da11a}.results-panel{background:var(--panel-bg);padding:2rem;border-radius:var(--radius-wobbly);box-shadow:var(--shadow-sm);border:3px solid var(--border-color);display:flex;flex-direction:column;gap:1.5rem;transform:rotate(-.5deg)}.ratio-score{text-align:center;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.ratio-score h3{font-size:1rem;color:var(--text-secondary);margin-bottom:.5rem}.score-value{font-size:3.5rem;font-weight:700;line-height:1;margin-bottom:.25rem;font-family:Kalam,cursive}.rating.good{color:#10b981;font-weight:600}.rating.poor{color:#ef4444;font-weight:600}.wcag-scores{display:flex;flex-direction:column;gap:1rem}.wcag-row{display:flex;justify-content:space-between;align-items:center}.wcag-info h4{font-size:.95rem;color:var(--text-primary)}.wcag-info p{font-size:.8rem;color:var(--text-secondary)}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:var(--radius-wobbly);border:2px solid var(--border-color);font-size:1rem;font-weight:600}.status-badge.pass{background:#d1fae5;color:#059669}.status-badge.fail{background:#fee2e2;color:#dc2626}.preview-box{padding:2rem;border-radius:var(--radius-wobbly);box-shadow:var(--shadow-sm);border:3px dashed var(--border-color);transition:all .3s;display:flex;align-items:center;justify-content:center}.preview-content{max-width:100%;margin:0 auto;text-align:center}.preview-content h3{font-size:1.5rem;margin-bottom:1rem}.preview-content p{font-size:1rem;line-height:1.6}@media(max-width:1024px){.checker-layout{grid-template-columns:1fr}}.gallery-container{width:100%;padding:2rem 5%;display:flex;flex-direction:column;gap:3rem}.gallery-header{text-align:center}.gallery-header h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:700;transform:rotate(1deg)}.gallery-section h3{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text-primary);border-bottom:3px dashed var(--border-color);padding-bottom:.5rem;font-family:Kalam,cursive}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media(max-width:1024px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.gallery-grid{grid-template-columns:1fr}}.gallery-card{background:var(--panel-bg);border-radius:var(--radius-subtle);overflow:hidden;box-shadow:var(--shadow-sm);border:3px solid var(--border-color);transition:transform .2s,box-shadow .2s}.gallery-card:hover{transform:translateY(-4px) rotate(2deg);box-shadow:var(--shadow-md)}.card-swatches{display:flex;height:120px;cursor:pointer;position:relative}.card-swatch{flex:1;height:100%}.card-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .2s;font-weight:500;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.card-overlay span{display:flex;align-items:center;gap:.5rem;transform:translateY(10px);transition:transform .2s}.card-swatches:hover .card-overlay{opacity:1}.card-swatches:hover .card-overlay span{transform:translateY(0)}.card-footer{padding:1rem;display:flex;align-items:center;justify-content:space-between}.card-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);font-family:Kalam,cursive}.delete-saved-btn{color:var(--text-primary);background:var(--panel-bg);border:3px solid var(--border-color);padding:.4rem;border-radius:var(--radius-oval);transition:all .2s}.delete-saved-btn:hover{color:#fff;background:var(--accent);transform:translateY(2px) rotate(5deg)}.app-container{display:flex;flex-direction:column;min-height:100vh}.navbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;position:sticky;top:10px;z-index:100;background:var(--panel-bg);border:3px solid var(--border-color);border-radius:var(--radius-subtle);box-shadow:var(--shadow-md);margin:0 10px;transform:rotate(-.5deg)}.logo{display:flex;align-items:center;gap:.75rem}.logo h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);transform:rotate(-2deg)}.logo-icon{font-size:1.5rem}.nav-links{display:flex;gap:1rem;background:transparent;padding:0;border:none}.nav-btn{padding:.5rem 1.25rem;font-size:1.1rem;font-weight:500;color:var(--text-primary);background-color:var(--panel-bg);border:3px solid var(--border-color);border-radius:var(--radius-oval);box-shadow:var(--shadow-sm);transition:var(--transition)}.nav-btn:nth-child(2n){transform:rotate(2deg)}.nav-btn:nth-child(odd){transform:rotate(-1deg)}.nav-btn:hover:not(.active){background-color:var(--accent);color:#fff;transform:translateY(2px) rotate(0);box-shadow:var(--shadow-pressed)}.nav-btn.active{background-color:var(--accent);color:#fff;box-shadow:var(--shadow-pressed);transform:translateY(2px) rotate(1deg)}.main-content{flex:1;display:flex;flex-direction:column}.placeholder-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary)}.placeholder-content h2{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.footer{padding:2rem;background-color:transparent;border-top:3px dashed var(--border-color);font-size:1.1rem;color:var(--text-primary)}.footer-content{max-width:1440px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.author-link{color:var(--accent);font-weight:600;text-decoration:none;font-family:Kalam,cursive;font-size:1.2rem}.author-link:hover{text-decoration:underline}.promo-text{font-size:1.1rem}.main-site-link{color:var(--blue-pen);font-weight:600;text-decoration:none;font-family:Kalam,cursive;font-size:1.2rem}.main-site-link:hover{text-decoration:underline}
