*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #F5F3EF;--color-bg-subtle: #EDEAE4;--color-surface: #FFFFFF;--color-surface-hover: #FAF9F7;--color-surface-raised: #FFFFFF;--color-primary: #B5543E;--color-primary-hover: #9A4633;--color-primary-light: rgba(181, 84, 62, .08);--color-text: #1A1A1F;--color-text-secondary: #7C7C88;--color-text-tertiary: #A8A8B3;--color-border: #E5E2DC;--color-border-light: #EDEBE6;--color-success: #2D7A50;--color-success-light: rgba(45, 122, 80, .08);--color-error: #BE3A34;--color-error-light: rgba(190, 58, 52, .08);--color-warning: #A67B1A;--color-warning-light: rgba(166, 123, 26, .08);--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.04);--shadow-lg: 0 12px 40px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.04);--nav-height: 64px;--font-display: "Instrument Serif", Georgia, serif;--font-body: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.025'/%3E%3C/svg%3E");background-repeat:repeat}#root{position:relative;z-index:1}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;font-size:15px;color:var(--color-text)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.container{max-width:620px;margin:0 auto;padding:24px 20px;padding-bottom:calc(var(--nav-height) + 32px);animation:fadeInUp .5s var(--ease-out) both}.page-title{font-family:var(--font-display);font-size:32px;font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin-bottom:24px;line-height:1.15}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;letter-spacing:.01em;transition:all .2s var(--ease-out);min-height:44px;width:100%;position:relative}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 1px 3px #b5543e40,inset 0 1px #ffffff1f}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 2px 8px #b5543e4d,inset 0 1px #ffffff1f;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 2px #b5543e33}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:#d5d3ce;box-shadow:var(--shadow);transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0)}.btn-danger{background:var(--color-error);color:#fff;box-shadow:0 1px 3px #be3a3440}.btn-danger:hover{background:#a8312c;transform:translateY(-1px)}.btn-small{padding:6px 14px;min-height:34px;font-size:13px;width:auto;border-radius:var(--radius-xs)}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:12px;font-weight:600;color:var(--color-text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.input-group input,.input-group select,.input-group textarea{width:100%;padding:11px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);transition:all .2s var(--ease-out);box-shadow:var(--shadow-xs)}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px var(--color-primary-light),var(--shadow-xs)}.input-group input::placeholder{color:var(--color-text-tertiary)}.card{background:var(--color-surface);border-radius:var(--radius);padding:16px 18px;border:1px solid var(--color-border-light);margin-bottom:10px;box-shadow:var(--shadow);transition:all .2s var(--ease-out)}.card:hover{box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.02em}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-neutral{background:#7c7c8814;color:var(--color-text-secondary)}.error-msg{color:var(--color-error);font-size:13px;font-weight:500;margin-top:10px}.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px}.month-nav button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 16px;font-size:18px;min-width:44px;min-height:44px;color:var(--color-text);box-shadow:var(--shadow-xs);transition:all .2s var(--ease-out)}.month-nav button:hover{background:var(--color-surface-hover);box-shadow:var(--shadow);transform:translateY(-1px)}.month-nav button:active{transform:translateY(0)}.month-nav span{font-family:var(--font-display);font-size:20px;font-weight:400;text-align:center;color:var(--color-text)}.hours-total{text-align:center;padding:14px 16px;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border-light);margin-bottom:20px;font-size:14px;font-weight:500;color:var(--color-text-secondary);box-shadow:var(--shadow)}.hours-total strong{color:var(--color-primary);font-size:20px;font-weight:700}.entry-card{display:flex;flex-direction:column;gap:4px}.entry-card .entry-header{display:flex;justify-content:space-between;align-items:center}.entry-card .entry-time{font-size:15px;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.entry-card .entry-hours{font-size:13px;font-weight:600;color:var(--color-primary)}.entry-card .entry-activity{font-size:13px;color:var(--color-text-secondary);line-height:1.45}.entry-card .entry-actions{display:flex;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border-light)}.entry-card .entry-actions button{font-size:12px;font-weight:600;padding:5px 12px;border-radius:var(--radius-xs);background:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border);transition:all .15s var(--ease-out)}.entry-card .entry-actions button:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:#d5d3ce}.entry-card .entry-actions .delete-btn:hover{background:var(--color-error-light);color:var(--color-error);border-color:#be3a3433}.date-group-header{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-top:20px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--color-border-light)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:#ffffffeb;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-top:1px solid var(--color-border-light);display:flex;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav a{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--color-text-tertiary);font-size:10px;font-weight:600;letter-spacing:.03em;gap:3px;padding:6px 16px;min-width:60px;border-radius:var(--radius-sm);transition:all .2s var(--ease-out)}.bottom-nav a:hover{color:var(--color-text-secondary)}.bottom-nav a.active{color:var(--color-primary)}.bottom-nav a svg{opacity:.5;transition:all .2s var(--ease-out)}.bottom-nav a:hover svg{opacity:.7}.bottom-nav a.active svg{opacity:1}.app-header{position:sticky;top:0;z-index:50;background:#ffffffe0;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-bottom:1px solid var(--color-border-light);padding:12px 20px;text-align:center}.app-header span{font-family:var(--font-display);font-weight:400;color:var(--color-text);letter-spacing:.01em}.form-row-3{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:12px}.form-row-3 .input-group input{padding:11px 10px;font-size:14px}.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--color-text-tertiary);font-size:14px;font-weight:500}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-tertiary);font-size:14px;font-weight:500}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalContentIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1f59;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;z-index:200;animation:modalOverlayIn .2s var(--ease-out) both}.modal-content{background:var(--color-surface);border-radius:20px 20px 0 0;padding:28px 24px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalContentIn .35s var(--ease-out) both}.modal-content h2{font-family:var(--font-display);font-size:22px;font-weight:400;margin-bottom:20px;color:var(--color-text)}.modal-actions{display:flex;gap:10px;margin-top:20px}.modal-actions .btn{flex:1}.admin-table{width:100%;overflow-x:auto}.admin-table table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th,.admin-table td{padding:10px 8px;text-align:left;border-bottom:1px solid var(--color-border-light)}.admin-table th{font-weight:600;color:var(--color-text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.06em}@media (min-width: 768px){.container{padding:32px 24px}.modal-overlay{align-items:center}.modal-content{border-radius:16px;max-width:500px;padding:32px 28px}}
