*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#1c1c1e;background-color:#fffdf5;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;min-height:100dvh;color:#e07b00;font-size:1rem}.loading:before{content:"";width:28px;height:28px;border:3px solid #fed7aa;border-top-color:#e07b00;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:1.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-family:Nunito,-apple-system,sans-serif;font-size:2.25rem;font-weight:800;color:#e07b00;letter-spacing:-.01em}.auth-header p{color:#666;margin-top:.25rem}.auth-form{width:100%;max-width:400px}.auth-form h2{font-size:1.25rem;margin-bottom:1rem}.auth-form label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:#333}.auth-form input{display:block;width:100%;min-height:48px;padding:.625rem .75rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;margin-bottom:.75rem;background:#fff;color:#1a1a1a;-webkit-appearance:none}.auth-form input:focus{outline:2px solid #E07B00;outline-offset:-1px;border-color:#e07b00}.auth-error{background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-bottom:.75rem}.auth-success{background:#f0fdf4;color:#16a34a;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-bottom:.75rem}.auth-forgot{text-align:right;margin-top:.5rem}.auth-forgot button{background:none;border:none;color:#6c6c70;font-size:.8125rem;cursor:pointer;padding:.25rem 0;-webkit-tap-highlight-color:transparent}.auth-forgot button:active{color:#e07b00}.btn-primary{display:block;width:100%;min-height:48px;padding:.75rem;font-size:1rem;font-weight:600;color:#fff;background:#e07b00;border:none;border-radius:.75rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-primary:active{background:#d4680a}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:1.25rem 0;color:#999;font-size:.875rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.auth-divider span{padding:0 .75rem}.btn-google{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;min-height:48px;padding:.75rem;font-size:1rem;font-weight:500;color:#333;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-google:active{background:#f3f4f6}.auth-toggle{margin-top:1.25rem;text-align:center;font-size:.875rem;color:#666}.auth-toggle button{background:none;border:none;color:#e07b00;font-weight:600;cursor:pointer;font-size:.875rem;padding:.25rem 0;-webkit-tap-highlight-color:transparent}.auth-toggle button:active{text-decoration:underline}.install-banner{background:#fff7ed;border:1px solid #fed7aa;border-radius:.75rem;padding:.875rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem}.install-banner-text{display:flex;flex-direction:column;gap:.25rem}.install-banner-text strong{font-size:.95rem;color:#9a3412}.install-banner-text span{font-size:.85rem;color:#9a3412;line-height:1.4}.install-banner-actions{display:flex;gap:.5rem}.install-btn{min-height:40px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:600;color:#fff;background:#ea580c;border:none;border-radius:.5rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.install-btn:active{background:#c2410c}.install-dismiss-btn{min-height:40px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;color:#9a3412;background:none;border:1px solid #fed7aa;border-radius:.5rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.install-dismiss-btn:active{background:#fef3c7}.install-share-icon{display:inline-block;vertical-align:middle;margin:0 .125rem;color:#ea580c}.install-banner-ios .install-dismiss-btn{align-self:flex-start}.layout{display:flex;flex-direction:column;min-height:100dvh;background:#fffdf5}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;padding-top:calc(.75rem + env(safe-area-inset-top));border-bottom:1px solid rgba(0,0,0,.06);background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.header-brand{display:flex;align-items:center;gap:.5rem}.header-logo{color:#e07b00}.app-header h1{font-family:Nunito,-apple-system,sans-serif;font-size:1.35rem;font-weight:800;letter-spacing:-.01em;background:linear-gradient(90deg,#c06800,#e8a020);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{position:relative}.btn-settings{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:50%;cursor:pointer;color:#8e8e93;-webkit-tap-highlight-color:transparent;transition:color .15s,background .15s}.btn-settings:active{background:#0000000d;color:#6c6c70}.settings-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 8px 24px #0000001f;min-width:140px;overflow:hidden;z-index:30}.settings-item{display:block;width:100%;padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:#dc2626;background:none;border:none;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.settings-item:active{background:#f9fafb}.settings-backdrop{position:fixed;inset:0;z-index:5}.app-content{flex:1;padding:1rem 1.25rem;padding-bottom:calc(4.5rem + env(safe-area-inset-bottom));overflow-y:auto}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);padding-bottom:env(safe-area-inset-bottom);z-index:10}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;min-height:52px;padding:.5rem 0;color:#8e8e93;text-decoration:none;font-size:.6875rem;font-weight:600;transition:color .15s;-webkit-tap-highlight-color:transparent;position:relative}.nav-tab:active{color:#b45309}.nav-tab.active{color:#e07b00}.nav-tab.active:after{content:"";position:absolute;bottom:calc(.25rem + env(safe-area-inset-bottom,0px));width:4px;height:4px;border-radius:50%;background:#e07b00}.page{padding:.5rem 0}.page h2{font-family:Nunito,-apple-system,sans-serif;font-size:1.6rem;font-weight:700;color:#1c1c1e;margin-bottom:.5rem;letter-spacing:-.01em}.placeholder-text{color:#9ca3af;text-align:center;padding:2rem 0}.offline-banner{text-align:center;padding:.5rem 1rem;font-size:.8rem;font-weight:500;z-index:20}.offline-banner-off{background:#fef3c7;color:#92400e;border-bottom:1px solid #fde68a}.offline-banner-on{background:#dcfce7;color:#166534;border-bottom:1px solid #bbf7d0}.dash-stats{display:flex;gap:.625rem;margin-top:1rem}.dash-stat-card{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem .5rem .75rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;box-shadow:0 2px 8px #c8640014;border-top:3px solid #F5A623;gap:.25rem}.dash-stat-today{border-top-color:#e07b00}.dash-stat-icon{color:#e07b00;margin-bottom:.125rem}.dash-stat-number{font-family:Nunito,-apple-system,sans-serif;font-size:2.25rem;font-weight:800;color:#1c1c1e;line-height:1;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}.dash-stat-number.dash-stat-animate{opacity:1;transform:translateY(0)}.dash-stat-label{font-size:.7rem;color:#6c6c70;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.dash-chart-container{margin-top:1.5rem}.dash-chart-container h3{font-family:Nunito,-apple-system,sans-serif;font-size:1rem;font-weight:700;color:#1c1c1e;margin-bottom:.75rem}.dash-chart{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;padding:.75rem .5rem .25rem;box-shadow:0 2px 8px #c864000f}.dash-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.375rem .625rem;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;gap:.125rem}.dash-tooltip-date{font-size:.75rem;color:#6c6c70}.dash-tooltip-count{font-size:.875rem;font-weight:700;color:#e07b00}.dash-empty{margin-top:2rem;text-align:center;padding:2rem 1.5rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;box-shadow:0 2px 8px #c864000f}.dash-empty-illustration{margin-bottom:.75rem}.dash-empty p{color:#6c6c70;font-size:1rem;margin-bottom:1.25rem;line-height:1.5}.dash-empty-btn{min-height:48px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;color:#fff;background:#e07b00;border:none;border-radius:.75rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s}.dash-empty-btn:active{background:#d4680a;transform:scale(.98)}.dash-tips{margin-top:1.5rem}.dash-tips h3{font-family:Nunito,-apple-system,sans-serif;font-size:1rem;font-weight:700;color:#1c1c1e;margin-bottom:.625rem}.dash-tip-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:.75rem;margin-bottom:.375rem;font-size:.9rem;color:#1c1c1e;box-shadow:0 1px 4px #c864000a}.dash-tip-emoji{font-size:1.25rem;flex-shrink:0}.dash-tip-card strong{color:#e07b00}.egg-date-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.5rem}.egg-date-label{font-size:1rem;color:#4b5563;font-weight:500}.egg-date-input{min-height:44px;padding:.375rem .5rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#1a1a1a;-webkit-appearance:none}.egg-date-input:focus{outline:2px solid #E07B00;outline-offset:-1px;border-color:#e07b00}.egg-counter-area{display:flex;flex-direction:column;align-items:center;margin:1.5rem 0 1rem;position:relative}.egg-counter-btn{width:140px;height:140px;border-radius:50%;border:4px solid #E07B00;background:linear-gradient(145deg,#fff8ed,#ffefd0);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.125rem;transition:transform .1s ease;box-shadow:0 4px 12px #e07b0033;-webkit-tap-highlight-color:transparent}.egg-counter-btn:active{transform:scale(.96)}.egg-counter-btn.egg-pulse{animation:egg-tap-pulse .2s ease-out}@keyframes egg-tap-pulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.egg-counter-plus{font-size:1rem;font-weight:700;color:#e07b00;line-height:1;opacity:.6}.egg-counter-number{font-family:Nunito,-apple-system,sans-serif;font-size:3rem;font-weight:800;color:#1c1c1e;line-height:1}.egg-counter-label{font-size:.875rem;color:#e07b00;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.egg-photo-thumb{margin-top:.75rem;width:64px;height:64px;border-radius:.5rem;overflow:hidden;border:2px solid rgba(224,123,0,.2)}.egg-photo-thumb img{width:100%;height:100%;object-fit:cover}.egg-controls{display:flex;align-items:center;justify-content:center;gap:.75rem}.egg-ctrl-btn{width:48px;height:48px;border-radius:50%;border:1px solid #d1d5db;background:#f9fafb;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#374151;-webkit-tap-highlight-color:transparent}.egg-ctrl-btn:active{background:#e5e7eb}.egg-ctrl-btn:disabled{opacity:.35;cursor:not-allowed}.egg-camera-btn{font-size:1.25rem}.egg-manual-input{width:64px;height:48px;text-align:center;font-size:1.125rem;font-weight:600;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#1a1a1a;-moz-appearance:textfield}.egg-manual-input::-webkit-inner-spin-button,.egg-manual-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.egg-manual-input:focus{outline:2px solid #E07B00;outline-offset:-1px;border-color:#e07b00}.egg-save-status{text-align:center;font-size:.8rem;font-weight:500;margin-top:.75rem;transition:opacity .3s}.egg-save-saving{color:#9ca3af}.egg-save-saved{color:#16a34a}.egg-save-error{color:#dc2626}.egg-recent{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.egg-recent h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:#374151}.egg-recent-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.egg-recent-item{display:flex;align-items:center;justify-content:space-between;min-height:48px;padding:.625rem .75rem;border-radius:.5rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.egg-recent-item:active{background:#e07b000f}.egg-recent-item.egg-recent-active{background:#e07b000f;border:1px solid rgba(224,123,0,.15)}.egg-recent-date{font-size:.9rem;color:#4b5563}.egg-recent-count{font-size:.9rem;font-weight:600;color:#e07b00}.alarm-cards{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.alarm-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;padding:1rem;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 4px #c864000a}.alarm-card.alarm-active{border-color:#e07b00;background:#fffdf5;box-shadow:0 2px 8px #e07b001a}.alarm-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.alarm-card-info{display:flex;align-items:center;gap:.75rem}.alarm-icon{font-size:1.5rem}.alarm-card-info h3{font-size:1rem;font-weight:600;line-height:1.2}.alarm-description{font-size:.8rem;color:#666;margin-top:.125rem}.toggle{position:relative;display:inline-block;width:48px;height:28px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background-color:#d1d5db;border-radius:28px;cursor:pointer;transition:background-color .2s}.toggle-slider:before{content:"";position:absolute;height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-slider{background-color:#e07b00}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.alarm-time-row{display:flex;align-items:center;gap:.75rem;margin-top:.75rem}.alarm-time-display{font-size:1.25rem;font-weight:700;color:#1a1a1a;min-width:5.5rem}.alarm-time-input{min-height:44px;padding:.375rem .5rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#1a1a1a;-webkit-appearance:none}.alarm-time-input:focus{outline:2px solid #E07B00;outline-offset:-1px;border-color:#e07b00}.day-selector{display:flex;gap:.375rem;margin-top:.75rem}.day-btn{width:40px;height:40px;border-radius:50%;border:1px solid #d1d5db;background:#fff;font-size:.85rem;font-weight:600;color:#666;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.day-btn.day-active{background:#e07b00;border-color:#e07b00;color:#fff}.day-btn:disabled{opacity:.5;cursor:not-allowed}.alarm-offline{background:#fef3c7;color:#92400e;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:.5rem}.alarm-error{background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:.5rem}.push-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.push-section h3{font-size:1.1rem;margin-bottom:.75rem}.push-section .btn-primary,.push-section .btn-secondary{display:block;width:100%;min-height:48px;padding:.75rem;font-size:1rem;font-weight:600;border:none;border-radius:.5rem;cursor:pointer}.push-section .btn-primary{background:#e07b00;color:#fff;-webkit-tap-highlight-color:transparent}.push-section .btn-primary:active{background:#d4680a}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;-webkit-tap-highlight-color:transparent}.btn-secondary:active{background:#e5e7eb}.push-section .btn-primary:disabled,.push-section .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.push-unsupported,.push-denied{color:#dc2626;font-size:.875rem}.push-error{background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:.75rem}.push-success{background:#f0fdf4;color:#16a34a;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:.75rem}.alarm-sound-btn{display:flex!important;align-items:center;justify-content:center;gap:.5rem}.alarm-sound-icon{font-size:1.25rem}.broody-offline{background:#fef3c7;color:#92400e;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:.5rem}.broody-form{margin-top:.75rem;padding:.875rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;box-shadow:0 1px 4px #c864000a}.broody-form-row{display:flex;gap:.5rem}.broody-name-input{flex:1;min-height:44px;padding:.5rem .75rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#1a1a1a}.broody-name-input:focus{outline:2px solid #E07B00;outline-offset:-1px;border-color:#e07b00}.broody-date-input{min-height:44px;padding:.25rem .5rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#1a1a1a;-webkit-appearance:none}.broody-date-input:focus{outline:2px solid #E07B00;outline-offset:-1px;border-color:#e07b00}.broody-add-btn{display:block;width:100%;min-height:48px;margin-top:.5rem;padding:.75rem;font-size:1rem;font-weight:600;color:#fff;background:#e07b00;border:none;border-radius:.75rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.broody-add-btn:active{background:#d4680a}.broody-add-btn:disabled{opacity:.5;cursor:not-allowed}.broody-empty{margin-top:1.5rem;padding:1.5rem 1rem;text-align:center;color:#6c6c70;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;box-shadow:0 2px 8px #c864000f;font-size:.95rem}.broody-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.broody-card{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:1rem;box-shadow:0 1px 4px #c864000a}.broody-card-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.broody-hen-name{font-size:1rem;font-weight:700;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.broody-day-count{font-size:.95rem;font-weight:600;color:#4b5563}.broody-day-7{color:#e07b00}.broody-day-14{color:#d4680a}.broody-day-21{color:#dc2626;font-weight:700}.broody-start-date{font-size:.8rem;color:#9ca3af}.broody-card-actions{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.broody-resolve-btn{min-height:48px;padding:.5rem .875rem;font-size:.875rem;font-weight:600;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.broody-resolve-btn:active{background:#dcfce7}.broody-delete-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#9ca3af;background:none;border:none;border-radius:50%;cursor:pointer;-webkit-tap-highlight-color:transparent}.broody-delete-btn:active{color:#dc2626;background:#fef2f2}.broody-resolved-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.broody-resolved-toggle{display:block;width:100%;min-height:48px;padding:.75rem;font-size:.9rem;font-weight:500;color:#6b7280;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent}.broody-resolved-toggle:active{background:#f3f4f6}.broody-resolved-list{list-style:none;display:flex;flex-direction:column;gap:.375rem;margin-top:.75rem}.broody-resolved-card{display:flex;flex-direction:column;gap:.125rem;padding:.625rem .75rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem}.broody-resolved-card .broody-hen-name{font-size:.9rem;color:#6b7280}.broody-resolved-detail{font-size:.8rem;color:#9ca3af}.broody-resolved-total{font-size:.8rem;font-weight:600;color:#6b7280}
