*{box-sizing:border-box}:root{color:#1f2937;background:linear-gradient(180deg,#f5f7fb,#eef3fb);font-family:Arial,sans-serif}body{margin:0}button,input{font:inherit}button{cursor:pointer}.page{min-height:100vh;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.header__logo{margin:0;font-size:30px;line-height:1.1}.auth-button,.profile__logout{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;border:1px solid transparent;border-radius:10px;transition:background .15s ease,border-color .15s ease,transform .15s ease}.auth-button{background:#2563eb;color:#fff}.auth-button:hover{background:#1d4ed8}.profile{display:flex;align-items:center;gap:12px;min-width:0}.profile__avatar{width:44px;height:44px;border-radius:50%;object-fit:cover}.profile__meta{display:flex;flex-direction:column;min-width:0;gap:4px}.profile__name{font-weight:700}.profile__hint{color:#5b6476;font-size:14px}.profile__logout{border-color:#d7dce5;background:#fff;color:#b42318}.profile__logout:hover{background:#fff3f2;border-color:#f0c5c1}.upload-panel{margin-bottom:24px;padding:14px 16px;border:1px solid #dfe5ef;border-radius:16px;background:#ffffffe6}.upload-input{display:none}.upload-panel__message{margin:0;color:#5b6476}.fab-upload{position:fixed;right:24px;bottom:24px;z-index:1050;display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border:none;border-radius:999px;background:#2563eb;color:#fff;box-shadow:0 18px 40px #2563eb52;transition:transform .16s ease,background .16s ease,box-shadow .16s ease}.fab-upload:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 22px 44px #2563eb61}.fab-upload:disabled{background:#95b4f2;box-shadow:0 12px 26px #2563eb2e;transform:none;cursor:not-allowed}.fab-upload svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.gallery__item{position:relative;display:flex;flex-direction:column;gap:10px;padding:16px;border:1px solid #e4e8f0;border-radius:16px;background:#fff;box-shadow:0 10px 30px #0f172a0a;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.gallery__item:hover{transform:translateY(-2px);border-color:#d6dde9;box-shadow:0 16px 36px #0f172a14}.gallery__top{display:grid;grid-template-columns:120px minmax(0,1fr);gap:16px;align-items:start}.gallery__preview{position:relative;display:flex;justify-content:flex-start;width:120px;height:104px;border:1px solid #dfe5ef;border-radius:14px;background:linear-gradient(180deg,#f8fafc,#eef3fb);overflow:hidden;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.gallery__preview:hover{border-color:#c9d5e6;box-shadow:inset 0 0 0 1px #fff6}.gallery__image{width:120px;max-width:100%;height:104px;object-fit:cover;cursor:pointer;border-radius:12px}.gallery__preview-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0f172a29;opacity:0;cursor:pointer;transition:opacity .16s ease}.gallery__preview:hover .gallery__preview-overlay{opacity:1}.gallery__preview-zoom{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:#ffffffeb;color:#1f2937;box-shadow:0 8px 20px #0f172a2e}.gallery__preview-zoom svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.gallery__delete-button{position:absolute;top:10px;right:10px;z-index:1}.gallery__empty{color:#667085}.gallery__status-badge{display:inline-flex;align-self:flex-start;margin:0;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.01em}.gallery__status-badge--uploaded{background:#eef2f7;color:#475467}.gallery__status-badge--processing{background:#e8f1ff;color:#1d4ed8}.gallery__status-badge--processed{background:#e8f7ee;color:#18794e}.gallery__status-badge--warning{background:#fff4db;color:#b54708}.gallery__status-badge--error{background:#fdecec;color:#b42318}.gallery__meta{display:flex;flex-direction:column;gap:6px;min-width:0}.gallery__content{display:flex;flex-direction:column;gap:10px}.gallery__content h4,.gallery__content p{margin:0}.gallery__content h4{margin-bottom:2px}.gallery__date{margin:0;color:#5f6b7a;font-size:13px}.gallery__summary-row{display:flex;align-items:flex-start;gap:8px}.gallery__summary-row p{flex:1}.gallery__tags{display:flex;flex-wrap:wrap;gap:6px}.gallery__tags span{padding:4px 8px;border-radius:999px;background:#eef3fb;font-size:13px}.gallery__text-section{display:flex;flex-direction:column;gap:8px}.gallery__text-actions{display:flex;align-items:center;gap:8px}.gallery__text-block{width:100%;margin:0;padding:10px;border-radius:10px;background:#f5f7fb;white-space:pre-wrap;text-align:left;line-height:1.45}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #d7dce5;border-radius:10px;background:#fff;transition:background .15s ease,border-color .15s ease,transform .15s ease}.icon-button:hover{background:#f5f7fb;border-color:#b8c1d1}.icon-button:active{transform:translateY(1px)}.icon-button svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.confirm-modal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px;background:#0f172a80}.confirm-modal__content{width:min(100%,360px);padding:20px;border-radius:16px;background:#fff;box-shadow:0 20px 50px #0f172a2e}.confirm-modal__title{margin:0 0 8px;font-size:20px}.confirm-modal__text{margin:0;color:#5b6476}.confirm-modal__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.confirm-modal__button{min-height:40px;padding:10px 14px;border:1px solid transparent;border-radius:10px}.confirm-modal__button--secondary{background:#fff;border-color:#d7dce5;color:#344054}.confirm-modal__button--danger{background:#b42318;color:#fff}.modal{position:fixed;inset:0;background:#0f172ad1;display:flex;align-items:center;justify-content:center;z-index:1000}.modal__content{position:relative;max-width:90vw;max-height:90vh}.modal__image{width:100%;height:auto;max-height:90vh;border-radius:12px}.modal__close{position:absolute;top:-10px;right:-10px;width:36px;height:36px;border:none;border-radius:50%;background:#fff}@media(max-width:980px){.gallery{grid-template-columns:1fr}}@media(max-width:720px){.page{padding:16px 16px 88px}.topbar{flex-direction:column;align-items:flex-start}.profile{width:100%;flex-wrap:wrap}}@media(max-width:320px){.gallery__top{grid-template-columns:1fr;gap:12px}.gallery__preview{justify-content:flex-start;width:120px;height:104px}.gallery__image{width:120px;height:104px}.profile{align-items:flex-start}.profile__logout,.auth-button{width:100%}.fab-upload{right:16px;bottom:16px;width:58px;height:58px}}
