html,body{overflow-x:hidden}body{background-size:400% 400%;animation:gradientBG 15s ease infinite;height:100vh;margin:0;font-family:Arial,sans-serif;position:relative}body:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-size:40px 40px;pointer-events:none}@keyframes gradientBG{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media (max-width: 768px){body{background-size:200% 200%}body:after{background-size:30px 30px}}#root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:linear-gradient(to bottom,#001f3f,#000)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--semi-circle-radius: 275px}.tuner-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100%}.tuner-container{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:100vh;justify-content:center;padding:20px;text-align:center;min-height:calc(100vh - 1px);transform-origin:center;transition:transform .3s ease;transform:scale(.8)}.semi-circle-container{position:relative;width:calc(var(--semi-circle-radius) * 2);height:calc(var(--semi-circle-radius) * 1.05);margin:20px auto;border-top-left-radius:var(--semi-circle-radius);border-top-right-radius:var(--semi-circle-radius);background:linear-gradient(to bottom,#001f3f,#000);overflow:visible;border-top:2px solid #ccc}.semi-circle-note{position:absolute;font-size:.9rem;font-weight:400;color:#a9a9a9;transform:translate(-50%,-50%);transition:color .3s ease,font-size .2s ease}.semi-circle-note.active{font-size:1.4rem;font-weight:700;color:#ff0}.start-listening{margin:20px;padding:10px 15px;font-size:1.5rem;background:#2196f3;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.feedback-text{color:gray;font-weight:400;font-size:1.5rem;padding:10px;margin:10px auto;background:linear-gradient(to bottom,#001f3f,#000);border-radius:8px;transition:color .3s ease;text-align:center}.tone-buttons{margin-top:20px;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.tone-buttons button{padding:8px 12px;font-size:14px;background:#444;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:transform .2s ease}.tone-buttons button:hover{transform:scale(1.1);background:#222}.detected-frequency{color:#a9a9a9;font-size:1.2rem;margin-top:10px}.horizontal-notes{position:relative;margin-top:10px;display:flex;justify-content:center;flex-wrap:wrap;gap:5px;padding:10px 0;background:linear-gradient(to bottom,#001f3f,#000);border-radius:8px}.horizontal-note{font-size:.8rem;font-weight:400;color:#a9a9a9;padding:5px;transition:color .3s ease,font-size .2s ease}.horizontal-note.active{font-size:1.2rem;font-weight:700;color:#ff0}.start-listening:hover{background-color:#005fa3}.start-listening:active{background-color:#00497d}.open-notes-buttons{margin-top:20px;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.open-notes-buttons button{padding:10px 15px;font-size:1.5rem;color:#fff;background-color:#444;border:none;border-radius:5px;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.open-notes-buttons button:hover{background-color:#666;transform:scale(1.05)}.open-notes-buttons button:active{background-color:#333;transform:scale(.95)}.center-tone{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:700;color:#ff0}@media screen and (max-width: 768px){.semi-circle-note{font-size:12px}}@media screen and (max-width: 400px){.semi-circle-note{font-size:8px}}.app{margin:0;padding:0;width:100%;justify-self:center;flex-direction:row}.buttonBox{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.button{font-size:.9rem;padding:.45rem 1rem;font-weight:500;border-radius:6px;border:1px solid #ccc;box-shadow:inset 0 1px #fff;cursor:pointer;transition:all .2s ease-in-out}.button-primary{background-color:#d6e6ff;color:#036;border:2px solid #003366;font-weight:700;padding:.5rem 1rem;border-radius:4px;box-shadow:3px 3px #036;transition:all .1s ease-in-out}.button-primary:hover{background-color:#c2dbff;box-shadow:1px 1px #036;transform:translate(2px,2px)}.button-secondary{background-color:#f0f0f0;color:#333;border:2px solid #333;font-weight:600;padding:.5rem 1rem;border-radius:4px;box-shadow:3px 3px #333;transition:all .1s ease-in-out}.button-secondary:hover{background-color:#e0e0e0;box-shadow:1px 1px #333;transform:translate(2px,2px)}.button-danger{background-color:#ffe6e6;color:#c00;border:2px solid #c00;border-radius:4px;font-weight:600;padding:.4rem 1rem;box-shadow:2px 2px #900;transition:all .1s ease}.button-danger:hover{box-shadow:1px 1px #900;transform:translate(1px,1px);background-color:#fdd}.button-tertiary{background-color:#fff;color:#222;border:2px solid #555;font-weight:600;font-size:.85rem;padding:.4rem .85rem;border-radius:4px;box-shadow:2px 2px #555;transition:all .1s ease-in-out;text-transform:uppercase;letter-spacing:.03em;cursor:pointer}.button-tertiary:hover{background-color:#f5f5f5;box-shadow:1px 1px #555;transform:translate(1px,1px)}.card{background:#fcfcfc;border:1px solid #ddd;border-radius:10px;box-shadow:0 2px 6px #0000000f;padding:1rem;margin-bottom:1rem}.icon-button{background:none;border:none;font-size:1rem;cursor:pointer;padding:.2rem;color:#666}.icon-button:hover{color:#c00}.layout{display:flex;flex-direction:row;justify-content:space-evenly;align-items:flex-start;gap:2rem;margin-top:2rem;width:100%}h2{font-size:1.25rem;font-weight:700;color:#222;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem;border-bottom:2px solid #ccc;padding-bottom:.25rem}h3{font-size:1rem;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}.panels{width:100%;display:flex;flex-direction:row;justify-content:center;align-items:flex-start;gap:2rem}.left-panel{flex-direction:column;padding:1rem;background:linear-gradient(to bottom right,#f9f9f9,#ededed);border:1px solid #ccc;border-radius:12px;box-shadow:0 4px 12px #00000014}.right-panel{width:70%;display:flex;flex-direction:column;gap:1.5rem;padding:1rem 1.25rem;background:linear-gradient(to bottom right,#fff,#f4f4f4);border:1px solid #ddd;border-radius:12px;box-shadow:0 4px 12px #0000000f}.timer-row-ui{display:flex;align-items:center;gap:1rem;background-color:#fff;padding:.75rem 1rem;border-radius:8px;box-shadow:0 2px 6px #0000001a}.timer-row-ui:not(:last-child){border-bottom:1px dashed #ccc;padding-bottom:1rem;margin-bottom:1rem}.timers-column{display:flex;flex-direction:row;gap:1rem;flex-flow:wrap}.goals-list{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.goal-row{display:flex;align-items:center;gap:.5rem}.goal-row input[type=text]{flex:1;padding:.25rem .5rem}.goal-row input[type=number]{width:55px;padding:.25rem;background-color:transparent;border:1px solid transparent}.goal-hours-label{font-size:.85rem;color:#555}.strike{text-decoration:line-through;color:#999}.goal-name-display{flex:1;padding:.25rem .5rem;cursor:pointer;background-color:transparent;border:1px solid transparent;border-radius:4px}.goal-name-display:hover{border-color:#ccc}.goal-description{width:90%;padding:.5rem;margin-top:.25rem;font-size:.7rem;resize:vertical;border-radius:6px;border:1px solid transparent;background-color:#f0f0f0;color:#333}.goal-description.strike{text-decoration:line-through;color:#999}.remove-goal-button{background-color:transparent;color:#fff;border:none;border-radius:4px;cursor:pointer}.score-list{list-style:none;padding-left:0;margin-top:.5rem}.score-list li{font-size:.9rem;margin-bottom:.25rem}.remove-score-button{font-size:.8rem;background:none;border:none;color:#b33;cursor:pointer;margin-top:.25rem}.remove-score-button:hover{color:#800}.mode-toggle-button{background-color:#ddd;border:none;padding:.4rem .8rem;border-radius:6px;cursor:pointer}.mode-toggle-button:hover{background-color:#bbb}.timer-durations{display:flex;gap:1rem;margin-top:.5rem;font-size:.85rem}.timer-durations label{display:flex;align-items:center;gap:.25rem}.timer-durations input{width:90px;font-size:.85rem;padding:.25rem}.timer-edit-input{font-size:1rem;text-align:center;padding:.2rem .4rem;width:90px}.readd-timer-button{font-size:.8rem;background:none;border:none;color:#369;cursor:pointer;margin-top:.25rem}.readd-timer-button:hover{color:#246}.editable-duration{width:"6em";border:"none";background:"transparent";font-size:"inherit";font-weight:"inherit";padding:0;outline:"none";cursor:"text"}input[type=text],span,div,button,select{font-family:IBM Plex Mono,monospace}.time-display{width:100%;padding:.5rem 1rem;font-size:1.25rem;font-weight:700;color:#036}@media (max-width: 768px){.layout,.panels{flex-direction:column;gap:1rem;align-items:stretch}.left-panel,.right-panel{max-width:100%}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.circle{position:relative;width:600px;height:600px;margin:50px auto;border-radius:50%;border:4px solid #ccc;display:flex;align-items:center;justify-content:center;background-color:#1c1c1c}.feedback-text.in-tune{color:#00c853}.feedback-text.sharp{color:#d32f2f}.feedback-text.flat{color:#1976d2}.feedback-text:hover{transform:scale(1.05)}button.start-listening{background:linear-gradient(to bottom,#001f3f,#000);color:#a9a9a9;border:none;border-radius:30px;padding:10px 20px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px #0003}button.start-listening:hover{transform:scale(1.05);box-shadow:0 6px 12px #0000004d}button.start-listening:active{transform:scale(.95);box-shadow:0 2px 4px #0003}.column-header{color:#fff}.journal-layout{display:flex;height:100vh;width:100vw;flex-direction:row}.journal-column{overflow-y:auto;padding:1rem}.journal-column-1{flex:1;border-right:1px solid #ccc}.journal-column-2{flex:1.5;border-right:1px solid #ccc}.journal-column-3{flex:1}@media (max-width: 768px){.journal-layout{flex-direction:column}.journal-column-1,.journal-column-2,.journal-column-3{flex:unset;border-right:none;border-bottom:1px solid #ccc}}.goal-button{background:transparent;border:none;color:#999;font-size:.9rem;cursor:pointer}
